3 回答
TA贡献1757条经验 获得超7个赞
您好,您的表达式 ${data[c].abbreviation} 会将值放入不带字符串引号的函数字符串中,即结果将是 onCurrencyClick(abbreviation)
而它应该是 < a i=2>. 请使用 onclick="onCurrencyClick("${data[c].abbreviation}")"相反。onCurrencyClick('abbreviation')
TA贡献1719条经验 获得超6个赞
不要使用内联onclick,而是使用事件委托。这意味着您有一个事件侦听器来处理来自子代和孙代的所有事件。修改是一个非常小的修改,请参见下面的示例。
这样做的原因是您将 JavaScript 保存在 JS 文件中。就像现在一样,您遇到了 JS 错误,并且必须在 HTML 中查找它。这可能会变得非常混乱。然而内联 onclick 监听器也是有效的,但它们已经过时了,应该避免,除非绝对没有其他方法。与 CSS 中使用 !important 进行比较,效果相同。
function onCurrencyClick(event){
var val = $(this).val();
setCookie("booking_currency", val, 14);
}
currencyMap.on('click', '.currency-item', onCurrencyClick);
此示例采用您尝试从单击的 的 属性插入的 val。 元素没有这样的属性,但是 有这样的属性,并且是一个更适合它期望与之交互的元素。将可点击元素用于点击等目的通常是一个很好的做法。 value.current-item<span><button>
在下面的示例中,您会看到正在使用的按钮以及在 属性中输出的 abbreviation 值3> 元素,可以从 函数中读取。value<button>onCurrencyClick
jQuery(document).ready(function($) {
$.getJSON('wp-content/themes/mundana/currency/currency.json', function(data) {
for(let c in data){
currencyMap.append(`
<button value="${data[c].abbreviation}" class="currency-item">
<span>
${data[c].symbol}
</span>
<span>
${data[c].currency}
</span>
</button>
`)
}
});
- 3 回答
- 0 关注
- 136 浏览
添加回答
举报