最近在用jQuery實現動態模糊查詢的時候,找了挺久都沒有找到像Vue.js的watch屬性這麼好用的動態模糊查詢方法。就分享一下目前遇到的坑和能夠實現動態查詢的幾種方式。css
1.jQuery的change()方法。jquery
這個方法要失去所在的input框的焦點時,事件纔會被觸發,感受有點雞肋,也有多是我沒有徹底會熟用這個方法,但願懂的大神能夠分享一下使用祕籍。數據庫
1 <input type="text" id="n3"/> 2 3 4 var $n3=$("#n3);//定位到input框 5 $n3.change(function(){ 6 this.query_search($n3.val());//query_search爲模糊查詢的方法 7 })
change()
函數用於爲每一個匹配元素的change事件綁定處理函數。該函數也可用於觸發change事件。此外,你還能夠額外傳遞給事件處理函數一些數據。change事件會在文本內容或選項被更改時觸發。該事件僅適用於<input type="text">和<textarea>以及<select>。對於text和textarea元素,該事件會在元素失去焦點時發生(文本內容也發生了更改)。此外,你能夠爲同一元素屢次調用該函數,從而綁定多個事件處理函數。觸發change事件時,jQuery會按照綁定的前後順序依次執行綁定的事件處理函數。要刪除經過change()
綁定的事件,請使用unbind()函數(本段摘自http://www.365mini.com/page/jquery-change.htm)。緩存
2.監聽JQuery的keyup或者keydown事件函數
這個方法能夠監聽每一個按鍵的觸發事件,能夠把模糊查詢方法綁定到響應的事件上,每按一次就會觸發一次模糊查詢的事件,可是這樣作會大大增長數據庫的壓力,若是人多操做並且沒有緩存的話,數據庫會分分鐘炸掉。測試
1 <input type="text" id="#n3"/> 2 3 var $n3=$("#n3");//定位到input框 4 $n3.keyup(function(){ 5 this.query_search($n3.prop("value"));//query_search爲模糊查詢的方法 6 })
3.使用Vue.js的watch屬性觀察者方法。this
這個方法能夠動態觀察input框裏面的屬性變化狀況,只要input框的value值發生變化,就會動態調用響應的方法。spa
最後值得一說的是,獲取input的text框裏面的value值有三種方法.code
1.經過attr("value")獲取。這種方法獲取只能獲取默認的。也就是說,你css代碼裏面原先定義的value值是多少,頁面第一次展示的也是多少,並且這個值不會變。htm
2.經過prop("value")獲取。這種方法能獲取默認的,也能獲取改變或的值,只要你改變了就能獲取到。
3.經過val()獲取。這個感受和prop("value")差很少。
4.也能夠用Vue.js的v-model綁定獲取到,那就算是4種方法吧。
以上這些都只是只是我的屢次測試得出的結論。並無什麼權威的說法,若是有錯誤,但願大神可以及時指正。