我正在尝试制作类似购物车的东西,但只是订购单。 我正在使用this pattern来触发输入更改,但在我的情况下它不起作用。
这是我的第一个。
<div class="ingrid__table-row">
<div class="ingrid__table-data ingrid__table-item">Lemon</div>
<div class="ingrid__table-data ingrid__table-weight">15g</div>
<div class="ingrid__table-data ingrid__table-price">10</div>
</div>
使用jQuery,点击后,我会从ingrid__table-data
获取数据并将合适的输入添加到.order__container
。
然后,在同一次点击时,会附加一个数字输入,这将使您能够选择所选产品的数量。
$('.order__container').append(`<input class="bul-order-info__input bul-order-info__qnt" type="number" name="Quantity" min="1" value="1">`)
它出现在订单表格的网页上。
我需要检测“数字类型输入”的值更改并触发其他事件。 但是未检测到输入更改,但如果我在HTML文档中手动创建相同的输入元素,则会在显示here
时完美地检测到这些更改我该如何实现这种行为?
答案 0 :(得分:2)
根据您提供的信息,我最好的猜测是您尝试以这种方式将on change事件附加到动态创建的输入:
$('.bul-order-info__input').change( function () {...} );
但是在使用代码之前,您还没有将这些更改应用于任何输入,因为在创建事件处理程序时它们都不存在,因此您必须将事件绑定到现有元素,如下所示:
$(document).on('change', '.bul-order-info__input', function() {...});
元素不一定总是文档,但我倾向于使用它,因为它是唯一一个始终存在的元素。但是,这样的事情也是有效的:
$('.order__container').on('change', '.bul-order-info__input', function() {...});