我想在 onclick
jQuery 中传递一个动态对象。请检查下面的代码片段,其中我获取的对象 product
值为 undefined
。有人可以帮助我了解如何在 JavaScript/jQuery 中传递和接收对象值吗?
var hpc = "";
function handleProductsClick(e, product) {
debugger;
alert(product && JSON.stringify(product));
}
function buildProducts(products) {
var bp = '';
hpc = handleProductsClick.bind(products[i]);
for (var i = 0; i < products.length; i++) {
bp += '<li onclick="hpc(event)">' + products[i].value + '</li>';
}
$("#products").html(bp);
}
function getProductsFromApi() {
var products = [{
key: 1,
value: "Apple"
},
{
key: 2,
value: "Android"
}
];
buildProducts(products);
}
getProductsFromApi();
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul id="products"></ul>
最佳答案
尝试使用 Javascript 中的事件监听器正确附加监听器,而不是内联 HTML 属性(这与 eval
一样糟糕)。另外,当您使用bind
时,第一个参数是提供给函数的this
值; .bind
的第二个参数对应于另一个函数中的第一个参数。
function handleProductsClick(product) {
console.log(product && JSON.stringify(product));
}
function buildProducts(products) {
products.forEach(product => {
const li = $('<li>' + product.value + '</li>');
li.on('click', handleProductsClick.bind(null, product));
$("#products").append(li)
});
}
function getProductsFromApi() {
var products = [{
key: 1,
value: "Apple"
},
{
key: 2,
value: "Android"
}
];
buildProducts(products);
}
getProductsFromApi();
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul id="products"></ul>
关于javascript - 在 onclick 中传递动态对象 - JavaScript/jQuery,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50564186/