The example in this article describes the oninput and onpropertychange methods of js and jquery that monitor the input box value in real time. Share it with everyone for your reference. The details are as follows:
I recently worked on a project, and the requirement was to automatically match keywords in the drop-down box. The specific details were to monitor the changes in the value of the text box in real time, and then match the relevant content.
When I first took on the project, the first thing I thought of was change in JQ, but I immediately ruled out this method because change is triggered when the text box loses focus. To save the country, I thought of using keydown to solve it. Everything else is fine, except that this event cannot be triggered when copying and pasting using the mouse instead of using the keyboard. So this method is also eliminated.
Then, I checked some relevant information and found that only the oninput & onpropertychange of native js met this requirement. Then I went to JQ's API to find a matching method. I was disappointed that I couldn't find it, but bind will indeed bind something like this. The event is input & propertychange. After passing the test, there is indeed no problem.
Now here is an example:
JQ:
$('input').bind('input propertychange', function() { //进行相关操作 });
Among them: propertychange is for compatibility with versions below IE9.
The oninput event in JS is not supported in versions below IE9. It needs to be replaced by IE's unique onpropertychange event. This event will be triggered when the user interface changes or when the content is directly modified using a script. There are the following situations:
The selected status of the input:checkbox or input:radio element has been modified, and the checked attribute has changed.
The value of the input:text or textarea element is modified, and the value attribute changes.
The selected item of the select element is modified, and the selectedIndex attribute changes.
JS:
if(isIE) { document.getElementById("input").onpropertychange = keys(); } else //需要用addEventListener来注册事件 { document.getElementById("input").addEventListener("input", keys, false); }
I hope this article will be helpful to everyone’s JavaScript programming design.