实时监听js改变value,跨浏览器支持

今天同事测试发现项目中一个小bug,而后我负责解决。研究了不短的时间,终于搞定了,有点激动。呵呵。拿出来与你们分享。

想要实现的功能大概是这样的:
有两个文本框,其中一个只读,另外一个能够输入。要求在可输入文本框中输入文本时,只读文本框可以得到输入的值,且只读文本框旁边出现提示信息,实时显示只读文本框的内容。

这个功能看是简单,但其实并无想象的那么简单。(注意,可输入框的处理没什么可讨论的,关键是只读框的处理)

一开始,咱们通常会想到在只读文本框上运用onchange事件。一试,发现onchange根本没用,该事件是在文本框得到焦点,而后内容改变失去焦点后才触发的,如今在只读文本框上根本没有这些,它的内容是经过js改变的。因而,须要寻找另外的方法。

这时,在网上找到了onpropertychange事件。该事件在文本框属性改变时触发,不论是经过什么方式改变的。注意,是属性改变,而不只仅是value改变。一试,果真好使。然而,这个事件是IE专有的。WEB开发,必须得考虑浏览器的兼容问题。因而继续摸索……

在网上有看到了另一个事件:oninput。网上处处都是:fireFox中的该事件与IE中onpropertychange的事件等同。然而,我一试,发现根本不等同。oninput事件在fireFox中彷佛没有起做用。通过一段时间测试,终于明白,原来oninput并不是与 onpropertychange等同(网上处处处处乱转贴,也不认真测试一下)。oninput只在用户输入值改变时触发(即value改变),并不是全部属性改变时触发,并且,经过js改变value时,oninput不会触发。这下郁闷了。好不容易看到点但愿,又再次陷入了失望,还好没有绝望……哎,浏览器兼容问题真是麻烦。

冥思苦想,总有又有了眉目。对于fireFox等浏览器,能够经过定时器检查只读文本框的内容是否改变。测试后,终于大功告成。下面把代码贴出来与你们分享。

在IE中的效果:
IE
在FireFox中的效果:
firefox
另外,我还在google Chrome测试也成功了(跟fireFox同样的)。
HTML代码

< table >
         < tr >
                     < td >此处值经过js设置: </td>
                     < td > < input id ="jsUserName" type ="text" name ="jsUserName" readonly /> </td>
             </tr>
             < tr >
                         < td >此处输入值: </td>
                         < td > < input id ="userName" type ="text" name ="userName" /> </td>
             </tr>
</table>

Javascript代码
$( function()
                {
                         var jsUserName = "";
                         if($.browser.msie)         // IE浏览器
                        {
                                $( "#userName").get(0).onpropertychange = setJsUserName;
                                $( "#jsUserName").get(0).onpropertychange = handle;
                        }
                         else         // 其余浏览器
                        {
                                 var intervalName;         // 定时器句柄
                                $( "#userName").get(0).addEventListener( "input",setJsUserName, false);
                                 // 得到焦点时,启动定时器
                                $( "#userName").focus( function(){
                                        intervalName = setInterval(handle,1000);
                                });

                                 // 失去焦点时,清除定时器
                                $( "#userName").blur( function()
                                {
                                        clearInterval(intervalName);
                                });
                        }
                         // 设置jsUserName input的值
                         function setJsUserName()
                        {
                                $( "#jsUserName").val($( this).val());
                        }
                         // jsUserName input的值改变时执行的函数
                         function handle()
                        {    
                                 // IE浏览器此处判断没什么意义,但为了统一,且提取公共代码而这样处理。
                                 if($( "#jsUserName").val() != jsUserName)
                                {
                                        $( "#toolTip").remove();
                                        $( "#jsUserName").parent().append( "<span id='toolTip'>看到这里的信息代表,经过js改变input的值也能响应相应事件:<span    style='color:red;'>" + $( "#jsUserName").val() + "</span></span>");
                                        jsUserName = $( "#jsUserName").val();
                                }
                        }
});


说明:为了方便,js代码使用了jQuery。不使用是同样的。
另外,考虑性能问题,能够考虑什么时候启动定时器和清除定时器以及定时器延时时间。
总结:
一、onchange事件与onpropertychange事件的区别: onchange事件在内容改变(两次内容有可能仍是相等的)且失去焦点时触发;onpropertychange事件倒是实时触发,即每增长或删除一个字符就会触发,经过js改变也会触发该事件,可是该事件IE专有。 二、oninput事件与onpropertychange事件的区别: oninput事件是IE以外的大多数浏览器支持的事件,在value改变时触发,实时的,即每增长或删除一个字符就会触发,然而经过js改变 value时,却不会触发;onpropertychange事件是任何属性改变都会触发的,而oninput却只在value改变时触发,oninput要经过addEventListener()来注册,onpropertychange注册方式跟通常事件同样。(此处都是指在js中动态绑定事件,以实现内容与行为分离) 三、oninput与onpropertychange失效的状况: (1)oninput事件:a). 当脚本中改变value时,不会触发;b). 从浏览器的自动下拉提示中选取时,不会触发。 (2)onpropertychange事件:当input设置为disable=true后,onpropertychange不会触发。 若有问题或本人写的不正确的地方欢迎联系或指正。
相关文章
相关标签/搜索