色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

在 JavaScript 中監聽 IME 鍵盤輸入事件

  在 JavaScript 中監聽用戶的鍵盤輸入是很容易的事情,但用戶一旦使用了輸入法,問題就變得復雜了。輸入法應當如何觸發鍵盤事件呢?是每一下擊鍵都觸發一次事件,還是選詞完畢才觸發事件呢?整句輸入又該如何觸發事件呢?不同的操作系統和不同的瀏覽器對此有不同的看法。在最糟糕的情況下,用戶使用輸入法后瀏覽器就只觸發一次 keydown ,之后就沒有任何的鍵盤事件了。這對于 Suggestion 控件的實現來說是個大問題,因為 Suggestion 控件需要監聽文本輸入框的變化,而事件是最準確也最節省計算資源的做法,如果換成輪詢的話性能就可能受到影響。

  首先,要監聽啟用輸入法后的擊鍵事件應當使用 keydown 事件,這是信息最豐富的一個事件,因為在啟用輸入法后別的鍵盤事件可能不會被觸發。其次,大多數操作系統和瀏覽器都實現了一個事實標準,就是在用戶使用輸入法輸入時, keydown 事件傳入的 keyCode 取值為 229 。然而觸發 keydown 的頻率是不確定的,有些情況下每一下擊鍵都觸發事件,有些情況下只有選詞完畢才觸發事件。這時候,如果我們還是要實時監控文本框的內容變化,就必須使用輪詢了。

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知識庫在 JavaScript 中監聽 IME 鍵盤輸入事件,轉載需保留來源!

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

主站蜘蛛池模板: 山阳县| 河北区| 江门市| 栖霞市| 中超| 内黄县| 定西市| 马公市| 吴旗县| 镇康县| 湛江市| 锦州市| 长阳| 临武县| 宁晋县| 禄丰县| 怀仁县| 莱芜市| 宁武县| 烟台市| 安庆市| 八宿县| 安宁市| 陆良县| 德江县| 会昌县| 泗水县| 调兵山市| 太谷县| 保亭| 水富县| 厦门市| 藁城市| 阳春市| 沾化县| 荔浦县| 大厂| 绥德县| 南澳县| 当雄县| 余江县|