jquery實(shí)現(xiàn)input輸入框?qū)崟r(shí)輸入觸發(fā)事件代碼

2018-08-22 19:41 更新
代碼如下:

<input id="productName" name="productName" class="wid10" type="text" value="" /> 

代碼如下:

//綁定商品名稱(chēng)聯(lián)想 
$('#productName').bind('input propertychange', function() {searchProductClassbyName();}); 

代碼如下:

searchProductClassbyName 為觸發(fā)后調(diào)用的方法; 

jQuery



js/jquery 實(shí)時(shí)監(jiān)聽(tīng)輸入框值變化的完美方案:oninput & onpropertychange  

(1)先說(shuō)jquery, 使用 jQuery 庫(kù)的話,只需要同時(shí)綁定 oninput 和 onpropertychange 兩個(gè)事件就可以了,示例代碼:
$('#username').bind('input propertychange', function() {
    $('#content').html($(this).val().length + ' characters');
});


(2)對(duì)于JS原生寫(xiě)法而言, oninput 是 HTML5 的標(biāo)準(zhǔn)事件,對(duì)于檢測(cè) textarea, input:text, input:password 和 input:search 這幾個(gè)元素通過(guò)用戶界面發(fā)生的內(nèi)容變化非常有用,在內(nèi)容修改后立即被觸發(fā),不像 onchange 事件需要失去焦點(diǎn)才觸發(fā)。oninput 事件在主流瀏覽器的兼容情況如下:

 

從上面表格可以看出,oninput 事件在 IE9 以下版本不支持,需要使用 IE 特有的 onpropertychange 事件替代,這個(gè)事件在用戶界面改變或者使用腳本直接修改內(nèi)容兩種情況下都會(huì)觸發(fā),有以下幾種情況:


修改了 input:checkbox 或者 input:radio 元素的選擇中狀態(tài), checked 屬性發(fā)生變化。
修改了 input:text 或者 textarea 元素的值,value 屬性發(fā)生變化。
修改了 select 元素的選中項(xiàng),selectedIndex 屬性發(fā)生變化。
  在監(jiān)聽(tīng)到 onpropertychange 事件后,可以使用 event 的 propertyName 屬性來(lái)獲取發(fā)生變化的屬性名稱(chēng)。


  集合 oninput & onpropertychange 監(jiān)聽(tīng)輸入框內(nèi)容變化的示例代碼如下:


 <head>
    <script type="text/javascript">
    // Firefox, Google Chrome, Opera, Safari, Internet Explorer from version 9
        function OnInput (event) {
            alert ("The new content: " + event.target.value);
        }
    // Internet Explorer
        function OnPropChanged (event) {
            if (event.propertyName.toLowerCase () == "value") {
                alert ("The new content: " + event.srcElement.value);
            }
        }
    </script>
</head>
<body>
    Please modify the contents of the text field.
    <input type="text" oninput="OnInput (event)" onpropertychange="OnPropChanged (event)"
     value="Text field" />
</body>
以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)