javascript - jQuery 将元素 ID 转换为逗号分隔的字符串

标签 javascript jquery

我有一个简单的 html 和 jquery 脚本,如下所示,我试图获得一个逗号分隔的数据项 ID 列表,所以看起来像...

1,2,3,4,5

var items = $('.container').children();
console.log(items);
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<div class="container">
  <div class="item" data-item-id="1">Item 1</div>
  <div class="item" data-item-id="2">Item 2</div>
  <div class="item" data-item-id="3">Item 3</div>
  <div class="item" data-item-id="4">Item 4</div>
  <div class="item" data-item-id="5">Item 5</div>
</div>

我已经抓取了项目,但如何将其转换为逗号分隔的字符串?

最佳答案

将每个项目映射到它的 item-id,然后用逗号连接:

var items = $('.container')
  .children()
  .map(function() { return $(this).data('item-id') })
  .get()
  .join(',');
console.log(items);
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<div class="container">
  <div class="item" data-item-id="1">Item 1</div>
  <div class="item" data-item-id="2">Item 2</div>
  <div class="item" data-item-id="3">Item 3</div>
  <div class="item" data-item-id="4">Item 4</div>
  <div class="item" data-item-id="5">Item 5</div>
</div>

但是,如果您愿意,不需要像 jQuery 这样的大型库来完成这种微不足道的事情:

const items = Array.from(
  document.querySelectorAll('.container > .item'),
  div => div.dataset.itemId
)
  .join(',');
console.log(items);
<div class="container">
  <div class="item" data-item-id="1">Item 1</div>
  <div class="item" data-item-id="2">Item 2</div>
  <div class="item" data-item-id="3">Item 3</div>
  <div class="item" data-item-id="4">Item 4</div>
  <div class="item" data-item-id="5">Item 5</div>
</div>

关于javascript - jQuery 将元素 ID 转换为逗号分隔的字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56334824/

相关文章:

javascript - 使用 ajax 编辑要点

javascript - 将图像和内容放入 jQuery 对话框中

javascript - 如何设置绝对位置div居中对齐

javascript - 对 ASP.NET MVC Controller 的 JQuery JSON POST 请求未到达端点,但手动使用路由工作正常

javascript - 单击说明该场景的图像后显示 Three.js 场景

jquery - 如何在砌体布局中将 div 居中?

javascript - toggleClass 在 ajax 中不起作用

javascript - addEventListener 创建了一个无限循环

javascript - JQuery 不适用于创建后的元素

javascript - 从多个 div 元素过滤时显示自定义消息在 JavaScript 中没有返回结果