当前位置:  开发笔记 > 编程语言 > 正文

为什么在启用自动填充功能时,javascript onchange事件不会触发?

如何解决《为什么在启用自动填充功能时,javascriptonchange事件不会触发?》经验,为你挑选了3个好方法。

我有一个带有onchange事件的文本框.当用户使用自动填充功能填充文本框时,为什么此事件不会触发?

我正在使用Internet Explorer.有没有一个标准的,相对简单的解决方案来解决这个问题,而我不必禁用自动完成功能?



1> Tom Jelen..:

上次我遇到这个问题时,我最终使用了onpropertychangeInternet Explorer 的事件.我在MSDN上看到了这个:它是推荐的解决方法.


注意:至少在我的测试中,onpropertychange似乎不再在IE9中可靠地工作.

2> Tim C..:

之前我遇到过这个恼人的功能,当时我的解决方案是使用onfocus事件来记录文本框的当前值,然后使用onblur事件来检查当前值是否与onfocus期间保存的值相匹配.例如



这是在最新版本的Chrome中发生的,所以显然它不是IE特定的东西.`onblur`解决了我的问题.
这对我很有用 - 这是我的jquerified翻译:`$("#my-field").focus(function(){this.originalvalue = this.value}).blur(function(){if(this.value! = this.originalvalue)alert('changed')});`

3> David Hammon..:

在Tim C的答案的基础上,这是我想出的一个简单的jquery来处理页面上所有文本框:

$("input[type=text]").bind("focus change",function(){
    this.previousvalue = this.value;
}).blur(function(){
    if (this.previousvalue != this.value){
        $(this).change();
    }
})

如果您不关心onchange多次触发,可以使其更简单:

$("input[type=text]").blur(function(){
    $(this).change();
})

推荐阅读
臭小子
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有