一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

修改jQuery.Autocomplete插件 支持中文輸入法 避免TAB、ENTER鍵失效、導致表單提交

但唯一遺憾的是,在對中文輸入法打開時,firefox3.0中是對中文拼音的自動匹配,而對輸入后的中文無法及時觸發匹配;而在我的IE6.0下,則無此問題。
原因分析:
Autocomplete插件對用戶輸入字符的觸發自動匹配是通過”keydown”事件進行的(可分析jquery.autocomplete.js第 92行),在IE6中,當輸入法打開時,輸入的字符是不會觸發”keydown”的,只有中文輸入完畢才觸發之,所以中文輸入和latin文沒有區別的;但在firefox3.0下,無論輸入法打開否,按鍵都會觸發”keydown”事件,所以造成中文輸入完畢,自動匹配的是剛才打出的部分中文拼音字母。 ------所以只有Firefox有問題。
解決方法:
網上查到的最多做法是修改jquery.autocomplete.js第92行,將”keydown”替換為”keyup”,但這個不是根本辦法,雖然這樣改后可在firefox中及時對輸入的中文進行自動匹配,但將原插件中回車、tab等重要的事件機制破壞了,比如這樣改后,如果你的input是在一個form里的話,回車從原來的將選定項輸入到input中變為了直接提交form表單了,這并不是我們想要的。
我的方法原理是,補充一個原插件觸發查詢的事件,就是當input輸入欄發生字符變化時,重新進行查詢(調用其內部的onChange函數),這里主要針對firefox而言,因為我們的系統訪問最多的是IE和firefox。而恰好firefox有一個input變化的事件就是oninput,那么我們只要在原jquery.autocomplete.js第199行,插入如下代碼:
復制代碼 代碼如下:
.bind("input", function() {
// @hack:support for inputing chinese characters in firefox
onChange(0, true);
});

插入后,代碼大概如下:
復制代碼 代碼如下:
...
...
jQueryinput.unbind();
jQuery(input.form).unbind(".autocomplete");
}).bind("input", function() {
// @hack:support for inputing chinese characters in firefox
onChange(0, true);
});
...

JavaScript技術修改jQuery.Autocomplete插件 支持中文輸入法 避免TAB、ENTER鍵失效、導致表單提交,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 在线色网址 | 久久66久这里精品99 | 色婷婷亚洲综合五月 | 4se视频在线观看 | 一级毛片国产真人永久在线 | 国产在线一区二区三区四区 | 国产综合在线观看视频 | 久久亚洲一级α片 | 中文字幕国产视频 | 激情婷婷成人亚洲综合 | 激情都市亚洲 | 国产精品网站在线进入 | 国产麻豆综合视频在线观看 | 一级毛片成人午夜 | 福利在线视频观看 | 精品99视频 | 久久中文精品 | 亚洲色吧 | 欧美成人高清免费大片观看 | 夜夜影院未满十八勿进 | 亚洲第一影院 | 亚洲欧美在线视频观看 | 欧美三级网站 | 精品一区二区三区三区 | 国产成人精品一区二区秒拍 | 国产亚洲精品国产福利在线观看 | 久久精品亚瑟全部免费观看 | 视频成人永久免费看 | 日日好吊妞 | 理论片中文字幕在线观看 | 久久久午夜视频 | 亚洲区欧美区小说区图片区 | 国产在线视频www色 国产在线视频第一页 | 亚洲福利视频网 | 色网站免费观看 | 91极品视频在线观看 | 亚洲欧美成人永久第一网站 | 欧美日韩一二三四区 | 成人免费xxx在线观看 | 婷婷丁香在线 | 最近免费中文在线视频 |