拨开荷叶行,寻梦已然成。仙女莲花里,翩翩白鹭情。
IMG-LOGO
主页 文章列表 如何将这些HTML属性添加到JavaScript物件?

如何将这些HTML属性添加到JavaScript物件?

白鹭 - 2022-02-11 2093 0 0

我有一个要放入物件的 div 内的属性串列 -

<div class="d-none product-data">
    <div class="product" product-name="English-One" translated-name="Translated-One"></div>
    <div class="product" product-name="English-Two" translated-name="Translated-Two"></div>
</div>

所以我遍历 .product-data .product 并像这样添加每个属性 -

$('.product-data .product').each(function () {
        translatedProducts = {
            "product": {
                "en": $(this).attr('product-name'),
                "tr": $(this).attr('translated-name')
            }
        }
});

但是,当我 console.log(translatedProducts) 我得到倍数时,它只添加了 English-Two -

Object { product: {…} }
product: Object { en: "English-Two", tr: "Translated-Two" }
en: "English-Two"
tr: "Translated-Two"

我如何撰写这个以便回圈遍历每个 div 并将 product-name 和 translate-name 属性添加到我的物件?

uj5u.com热心网友回复:

您正在覆写同一个物件。物件不能有相同的键,所以后者会覆写前者。:

看起来好像您希望将物件变成一个更大的物件。如果你想要两个物件,把它们放在一个阵列中:

此外,您应该使用data-*属性,自定义键就是它们的用途。

let products = [];
let translatedProducts = {};

$('.product').each(function(i) {
  let product = {};
  product.en = $(this).data('product');
  product.tr = $(this).data('translated');
  products.push(product);
});

translatedProducts.products = products;

console.log(translatedProducts);
<div class="d-none product-data">
    <div class="product" data-product="English-One" data-translated="Translated-One"></div>
    <div class="product" data-product="English-Two" data-translated="Translated-Two"></div>
</div>

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

uj5u.com热心网友回复:

使用一个阵列并将每组单独的值推送给它

var translatedProducts = [];
$('.product-data .product').each(function () {
        translatedProducts.push( {
            "product": {
                "en": $(this).attr('product-name'),
                "tr": $(this).attr('translated-name')
            }
        });
});
标签:

0 评论

发表评论

您的电子邮件地址不会被公开。 必填的字段已做标记 *