使用JQuery检测<inputtype=“text”>(立即)的所有更改的值有很多种方法。<input type="text">可以改变,包括:按键复制/粘贴用JavaScript修改由浏览器或工具栏自动完成我希望在JavaScript函数发生变化时(使用当前的输入值)调用它。我希望它被立即调用,而不仅仅是当输入失去焦点时。我正在寻找在所有浏览器上(最好使用jQuery)的最干净和最健壮的方法来实现这一点。示例用例:在Twitter注册页,用户名字段的值显示在url中“http://twitter/用户名“在它下面。
3 回答
临摹微笑
TA贡献1982条经验 获得超2个赞
$('.myElements').each(function() { var elem = $(this); // Save current value of element elem.data('oldVal', elem.val()); // Look for changes in the value elem.bind("propertychange change click keyup input paste", function(event){ // If value has changed... if (elem.data('oldVal') != elem.val()) { // Updated stored value elem.data('oldVal', elem.val()); // Do action .... } }); });
哈士奇WWW
TA贡献1799条经验 获得超6个赞
$("#input-id").on("change keyup paste", function(){ dosomething();})
$("#input-id").on("change keyup paste click", function(){ dosomething();})
live
on
.
蓝山帝景
TA贡献1843条经验 获得超7个赞
setInterval
<input type=text id=input_id /><script>setInterval(function() { ObserveInputValue($('#input_id').val()); }, 100);</script>
input
100 ms的潜伏期?
对于许多应用程序来说,100 ms就足够快了。 在浏览器上添加了负载?
通常来说,在页面上添加大量的重集交换是不好的。但是在这种情况下,添加的页面加载是无法检测的。 它不会扩展到很多输入?
大多数页面只有少数输入,您可以在同一个setInterval中嗅探所有输入。
添加回答
举报
0/150
提交
取消