博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
实时监听js改变value,跨浏览器支持
阅读量:4125 次
发布时间:2019-05-25

本文共 2725 字,大约阅读时间需要 9 分钟。

想要实现的功能大概是这样的:

有两个文本框,其中一个只读,另一个可以输入。要求在可输入文本框中输入文本时,只读文本框能够获得输入的值,且只读文本框旁边出现提示信息,实时显示只读文本框的内容。
这个功能看是简单,但其实并没有想象的那么简单。(注意,可输入框的处理没什么可讨论的,关键是只读框的处理)

一开始,我们一般会想到在只读文本框上运用onchange事件。一试,发现onchange根本没用,该事件是在文本框获得焦点,然后内容改变失去焦点后才触发的,现在在只读文本框上根本没有这些,它的内容是通过js改变的。于是,需要寻找另外的方法。

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

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

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

在google Chrome测试也成功了(跟fireFox一样的)。

HTML代码:

 

JavaScript代码

 

 

说明:为了方便,js代码使用了jQuery。不使用是一样的。

另外,考虑性能问题,可以考虑何时启动定时器和清除定时器以及定时器延时时间。

总结:

1、onchange事件与onpropertychange事件的区别:

onchange事件在内容改变(两次内容有可能还是相等的)且失去焦点时触发;onpropertychange事件却是实时触发,即每增加或删除一个字符就会触发,通过js改变也会触发该事件,但是该事件IE专有。

2、oninput事件与onpropertychange事件的区别:

oninput事件是IE之外的大多数浏览器支持的事件,在value改变时触发,实时的,即每增加或删除一个字符就会触发,然而通过js改变value时,却不会触发;onpropertychange事件是任何属性改变都会触发的,而oninput却只在value改变时触发,oninput要通过addEventListener()来注册,onpropertychange注册方式跟一般事件一样。(此处都是指在js中动态绑定事件,以实现内容与行为分离)

3、oninput与onpropertychange失效的情况:

(1)oninput事件:a). 当脚本中改变value时,不会触发;b). 从浏览器的自动下拉提示中选取时,不会触发。
(2)onpropertychange事件:当input设置为disable=true后,onpropertychange不会触发

 

 

 

 

 

 

转载地址:http://pjlpi.baihongyu.com/

你可能感兴趣的文章
Linux-4.20.8内核桥收包源码解析(一)----------sk_buff(详细)
查看>>
Linux-4.20.8内核桥收包源码解析(二)----------sk_buff的操作
查看>>
Linux-4.20.8内核桥收包源码解析(四)----------netif_receive_skb
查看>>
Linux-4.20.8内核桥收包源码解析(五)----------桥处理流程br_handle_frame
查看>>
Linux-4.20.8内核桥收包源码解析(六)----------决策函数br_handle_frame_finish
查看>>
Linux-4.20.8内核桥收包源码解析(七)----------本地(br_pass_frame_up)or 转发(br_forward)
查看>>
内核中新增驱动代码目录和子目录
查看>>
Maven实现原理
查看>>
Java线程基础
查看>>
线程并发工具类(Fork-Join,CountDownLatch,CyclicBarrier,Semaphore,Exchange)
查看>>
原子操作CAS
查看>>
为什么wait()和notify()需要搭配synchonized关键字使用
查看>>
ThreadLocal及其原理
查看>>
JDK命令行工具的监控
查看>>
《OS、Network、Kernel》PDF资源汇总
查看>>
条件变量 pthread_cond_init
查看>>
关于vim,ctags的一个小技巧
查看>>
最小生成树 - E - QS Network
查看>>
最小生成树 - H - Highways
查看>>
洛谷 P1443 马的遍历(BFS)
查看>>