|
在 JavaScript 中監(jiān)聽(tīng)用戶的鍵盤輸入是很容易的事情,但用戶一旦使用了輸入法,問(wèn)題就變得復(fù)雜了。輸入法應(yīng)當(dāng)如何觸發(fā)鍵盤事件呢?是每一下?lián)翩I都觸發(fā)一次事件,還是選詞完畢才觸發(fā)事件呢?整句輸入又該如何觸發(fā)事件呢?不同的操作系統(tǒng)和不同的瀏覽器對(duì)此有不同的看法。在最糟糕的情況下,用戶使用輸入法后瀏覽器就只觸發(fā)一次 keydown
,之后就沒(méi)有任何的鍵盤事件了。這對(duì)于 Suggestion 控件的實(shí)現(xiàn)來(lái)說(shuō)是個(gè)大問(wèn)題,因?yàn)?Suggestion 控件需要監(jiān)聽(tīng)文本輸入框的變化,而事件是最準(zhǔn)確也最節(jié)省計(jì)算資源的做法,如果換成輪詢的話性能就可能受到影響。
首先,要監(jiān)聽(tīng)啟用輸入法后的擊鍵事件應(yīng)當(dāng)使用 keydown
事件,這是信息最豐富的一個(gè)事件,因?yàn)樵趩⒂幂斎敕ê髣e的鍵盤事件可能不會(huì)被觸發(fā)。其次,大多數(shù)操作系統(tǒng)和瀏覽器都實(shí)現(xiàn)了一個(gè)事實(shí)標(biāo)準(zhǔn),就是在用戶使用輸入法輸入時(shí), keydown
事件傳入的 keyCode
取值為 229
。然而觸發(fā) keydown
的頻率是不確定的,有些情況下每一下?lián)翩I都觸發(fā)事件,有些情況下只有選詞完畢才觸發(fā)事件。這時(shí)候,如果我們還是要實(shí)時(shí)監(jiān)控文本框的內(nèi)容變化,就必須使用輪詢了。
var timer;
var imeKey = 229;
function keydownHandler (e) {
clearInterval(timer)
if (e.keyCode == imeKey) {
timer = setInterval(checkTextValue, 50);
} else {
checkTextValue();
}
}
function checkTextValue() {
/* handle input text change */
}
it知識(shí)庫(kù):在 JavaScript 中監(jiān)聽(tīng) IME 鍵盤輸入事件,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。