当我用按钮更改文本框的值时,我试图触发文本框上的更改事件,但它不起作用。检查这把小提琴。
如果在文本框中键入内容,然后单击其他地方,则会触发更改。但是,如果单击该按钮,文本框值将被更改,但不会触发更改。为什么?
当我用按钮更改文本框的值时,我试图触发文本框上的更改事件,但它不起作用。检查这把小提琴。
如果在文本框中键入内容,然后单击其他地方,则会触发更改。但是,如果单击该按钮,文本框值将被更改,但不会触发更改。为什么?
当前回答
从https://api.jquery.com/change/:
当元素的值发生变化时,change事件被发送到元素。此事件仅限于<input>元素,<textarea>框和<select>元素。对于选择框、复选框和单选按钮,当用户使用鼠标进行选择时,事件将立即触发,但对于其他元素类型,事件将延迟到元素失去焦点。
其他回答
截至2019年2月,. addeventlistener()目前还不能使用jQuery .trigger()或.change(),您可以使用Chrome或Firefox在下面测试它。
三种。addEventListener('input', function() { console.log('不叫吗? '); }) $ (' # txt) .val .trigger(“测试”)(“输入”); $ (' # txt) .trigger(“输入”); $ (' # txt) .change (); < script src = " https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js " > < /脚本> <input type="text" id="txt">
你必须使用. dispatchevent()来代替。
三种。addEventListener('input', function() { console.log(“它!”); }) $ (' # txt) .val(“是”) 三种。dispatchEvent(新事件(“输入”)); < script src = " https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js " > < /脚本> <input type="text" id="txt">
你需要像这样链接这个方法:
$('#input').val('test').change();
Onchange只在用户输入时触发,然后输入失去焦点。
你可以手动调用onchange事件使用设置后的值:
$("#mytext").val( 777 ).change(); // someObject.onchange(); in standard JS
或者,您可以使用以下命令触发事件:
$("#mytext").val( 777 ).trigger("change");
您可以使用attr和val方法,然后触发更改:
$('.parent-form').find('input').each(function() {
item = $(this);
item.attr('value', '0622-03-22');
item.val('01/01/01').trigger('change');
});
不,你可能需要在设置值后手动触发它:
$('#mytext').change();
or:
$('#mytext').trigger('change');