因為輸入法或瀏覽器的問題,在輸入中文後並沒有觸發自動完成,要再按多一下鍵盤才觸發,檢視發現它是用keydown來實現
.bind("keydown.autocomplete", function(event) {
....
})
可以對其input事件進行監聽來解決問題,在上面的程式碼後繫結一個input事件
.bind("input.autocomplete",function(event){ if(suppressKeyPress){ suppressKeyPress = false; event.preventDefault(); } clearTimeout(self.searching); self.searching = setTimeout(function(){ if(self.term != self.element.val()){ self.selectedItem = null; self.search(null, event); } }, self.options.delay); })
其內容參照 keydown的default處理
Min版修改
//找到 default:clearTimeout(b.searching),b.searching=setTimeout(function(){b.term!=b.element.val()&&(b.selectedItem=null,b.search(null,c))},b.options.delay)}}}) //在這後加上 .bind("input.autocomplete",function(a){clearTimeout(b.searching),b.searching=setTimeout(function(){b.term!=b.element.val()&&(b.selectedItem=null,b.search(null,c))},b.options.delay)}) //接上後面的 .bind("keypress.autocomplete",function(a){