四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

在 JavaScript 中監(jiān)聽 IME 鍵盤輸入事件

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

  首先,要監(jiān)聽啟用輸入法后的擊鍵事件應(yīng)當使用 keydown 事件,這是信息最豐富的一個事件,因為在啟用輸入法后別的鍵盤事件可能不會被觸發(fā)。其次,大多數(shù)操作系統(tǒng)和瀏覽器都實現(xiàn)了一個事實標準,就是在用戶使用輸入法輸入時, keydown 事件傳入的 keyCode 取值為 229 。然而觸發(fā) keydown 的頻率是不確定的,有些情況下每一下?lián)翩I都觸發(fā)事件,有些情況下只有選詞完畢才觸發(fā)事件。這時候,如果我們還是要實時監(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知識庫在 JavaScript 中監(jiān)聽 IME 鍵盤輸入事件,轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 无声真相电影免费播放| 十一码复式中奖表图片| 掐脖子的视频| 一江春水向东流 电视剧| 丰满美女| 微信头像大全500张| 秋霞影视| 南贤俊| 追捕演员表名单| 李洋演员个人简介图片| 十八岁在线观看| 抖音最火的图片| 九州电影网| 巨齿鲨2:深渊 电影| 消防知识问答100题| 在线播放三级| 女生宿舍2在线看| 唐朝艳妃电影| 拔萝卜无删减| 张筱雨粉嫩啪啪人体| 亚洲第一区se| disturbia| 傅青主治闭经特效方| 大胆艺术| 绝伦海女| 电视剧《流金岁月》演员表| 四年级下册语文猫课堂笔记| 碑文格式范例 墓碑图片| 老阿姨电视剧免费观看| 挨饿游戏| 就要爱| 女同性电影| 《与凤行》演员表| 罗比威廉姆斯| 鲁滨逊漂流记阅读笔记| 王兴德| 嫦娥奔月读后感50字| 柏拉图的电影| 咒怨:终结的开始| 2018年党课主题及内容| 安静书素材可打印|