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

有效的捕獲JavaScript焦點的方法小結

1. 設置元素可獲得焦點以監聽鍵盤事件
元素聚焦最大好處就是可允許發送鍵盤事件,HTML很多元素默認就有可聚焦,如form表單元素,a錨鏈接等,但大部份默認是不能聚焦的。要使得元素能夠聚焦,可以在HTML代碼或JavaScript腳本中實現。
html:
復制代碼 代碼如下:
<div tabIndex="0" style="height:100px;width:100px; background:red;"></div>

JavaScript:
oDiv.tabIndex = 0;
其中tabIndex是TAB鍵的導航順序,可有正,負或零。
當元素獲得焦點時會有邊框指示,如果想不顯示這個邊框,可以
html:
復制代碼 代碼如下:
<div tabIndex="0" hidefocus="on" ></div>

JavaScript:
oDiv.hideFocus = ‘on';
2. 元素明明設置了聚焦卻沒效果
有時用JavaScript設置了元素聚焦,但最后焦點卻不落在該元素上,百思不得其解。
問題在于如果在可焦點元素的事件處理函數中聚焦其它元素,就有可能聚不了焦點,因為如果該事件是個可獲得焦點的事件,如mouse, keydow(keypress)等等,在這些事件的處理函數內直接聚焦其它元素是失敗的。
復制代碼 代碼如下:
oDiv.onmousedown = function(){
document.getElementById('ipt').focus();
};

參考瀏覽器內核處理流程圖:

當瀏覽器第一次Reflow回流后,焦點停在另一個元素上,但回流返回后,事件處理后默認的操作將繼續執行,那就是聚焦到事件源,也就是mousedown的元素,這時引發第二次回流,當回流后焦點聚在該元素上.所以在事件處理函數中的聚焦變得無效.

有沒解決方法? 答案是肯定的. 由圖可知,只要把聚焦放到第二個Reflow回流之后執行即可.這個可利用setTimeout方法作延遲先放進隊列等后再執行.因為由于JavaScript引擎單線程特性,圖上整個過程都是連著執行的,該過程中JS引擎一直沒有空閑過,當上面所有操作都完成后并后,定時回調才有機會被執行.所以可以:
復制代碼 代碼如下:
oDiv.onmousedown = function(){
setTimeout(function(){
document.getElementById('ipt').focus();
}, 0);
};

由上可知,最后那個毫秒數即使設為0也沒關系.

3. 聚焦時拋出異常的
在IE中,當元素不可見時如果聚焦的話,會拋出一個異常,因為在很多應用中我們往往不再對元素是否不可見作測試就聚焦了,因為即使這樣也沒什么問題(誰說不可見元素就不可以聚焦的?)..所以,在IE下可用try{}catch(){}來忽略這個異常.
復制代碼 代碼如下:
try{
element.focus();
}catch(e){}

到此,與JavaScript焦點捕獲相關的問題討論就完成了.

JavaScript技術有效的捕獲JavaScript焦點的方法小結,轉載需保留來源!

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

主站蜘蛛池模板: 激情福利网站 | 香蕉免费一区二区三区在线观看 | 亚洲成片在线观看12345ba | 成年美女黄网站色大免费视频 | 一区二区三区四区在线不卡高清 | 亚洲乱亚洲乱妇41p国产成人 | 亚洲一区2区三区4区5区 | 亚洲天堂五月天 | 成人信息集中地 | 欧美日韩国产一区二区三区不卡 | 欧美一区色 | 国产精品一区二区三 | 两性色| 成人国产在线视频在线观看 | 一本久道久久综合多人 | 性欧美4k高清精品 | 末成年美女黄网站色大片连接 | 午夜在线观看视频免费 成人 | 欧美成人免费全部观看天天性色 | 视频在线观看一区二区三区 | 偷偷碰偷偷鲁免费视频 | 一区二区三区免费高清视频 | 天天色综 | 中文资源在线观看 | 亚洲欧洲色天使日韩精品 | 国产91在线精品福利 | 欧美高清在线观看视频 | 国产成人啪精品午夜在线播放 | 麻豆a | 伊人免费在线 | 91网站免费在线观看 | 美女很黄很黄免费 | 四虎激情 | 久久中文网 | 韩国亚洲伊人久久综合影院 | 日本久久久久久久中文字幕 | 色视频www在线播放国产人成 | 91精品一区二区三区久久久久 | 国产91色拍 | 亚洲综合一区二区 | 草草线在成年免费视频网站 |