有效的捕獲JavaScript焦點(diǎn)的方法小結(jié)
元素聚焦最大好處就是可允許發(fā)送鍵盤事件,HTML很多元素默認(rèn)就有可聚焦,如form表單元素,a錨鏈接等,但大部份默認(rèn)是不能聚焦的。要使得元素能夠聚焦,可以在HTML代碼或JavaScript腳本中實(shí)現(xiàn)。
html:
<div tabIndex="0" style="height:100px;width:100px; background:red;"></div>
JavaScript:
oDiv.tabIndex = 0;
其中tabIndex是TAB鍵的導(dǎo)航順序,可有正,負(fù)或零。
當(dāng)元素獲得焦點(diǎn)時(shí)會(huì)有邊框指示,如果想不顯示這個(gè)邊框,可以
html:
<div tabIndex="0" hidefocus="on" ></div>
JavaScript:
oDiv.hideFocus = ‘on';
2. 元素明明設(shè)置了聚焦卻沒(méi)效果
有時(shí)用JavaScript設(shè)置了元素聚焦,但最后焦點(diǎn)卻不落在該元素上,百思不得其解。
問(wèn)題在于如果在可焦點(diǎn)元素的事件處理函數(shù)中聚焦其它元素,就有可能聚不了焦點(diǎn),因?yàn)槿绻撌录莻€(gè)可獲得焦點(diǎn)的事件,如mouse, keydow(keypress)等等,在這些事件的處理函數(shù)內(nèi)直接聚焦其它元素是失敗的。
oDiv.onmousedown = function(){
document.getElementById('ipt').focus();
};
參考瀏覽器內(nèi)核處理流程圖:

當(dāng)瀏覽器第一次Reflow回流后,焦點(diǎn)停在另一個(gè)元素上,但回流返回后,事件處理后默認(rèn)的操作將繼續(xù)執(zhí)行,那就是聚焦到事件源,也就是mousedown的元素,這時(shí)引發(fā)第二次回流,當(dāng)回流后焦點(diǎn)聚在該元素上.所以在事件處理函數(shù)中的聚焦變得無(wú)效.
有沒(méi)解決方法? 答案是肯定的. 由圖可知,只要把聚焦放到第二個(gè)Reflow回流之后執(zhí)行即可.這個(gè)可利用setTimeout方法作延遲先放進(jìn)隊(duì)列等后再執(zhí)行.因?yàn)橛捎贘avaScript引擎單線程特性,圖上整個(gè)過(guò)程都是連著執(zhí)行的,該過(guò)程中JS引擎一直沒(méi)有空閑過(guò),當(dāng)上面所有操作都完成后并后,定時(shí)回調(diào)才有機(jī)會(huì)被執(zhí)行.所以可以:
oDiv.onmousedown = function(){
setTimeout(function(){
document.getElementById('ipt').focus();
}, 0);
};
由上可知,最后那個(gè)毫秒數(shù)即使設(shè)為0也沒(méi)關(guān)系.
3. 聚焦時(shí)拋出異常的
在IE中,當(dāng)元素不可見時(shí)如果聚焦的話,會(huì)拋出一個(gè)異常,因?yàn)樵诤芏鄳?yīng)用中我們往往不再對(duì)元素是否不可見作測(cè)試就聚焦了,因?yàn)榧词惯@樣也沒(méi)什么問(wèn)題(誰(shuí)說(shuō)不可見元素就不可以聚焦的?)..所以,在IE下可用try{}catch(){}來(lái)忽略這個(gè)異常.
try{
element.focus();
}catch(e){}
到此,與JavaScript焦點(diǎn)捕獲相關(guān)的問(wèn)題討論就完成了.
- 在js(jquery)中獲得文本框焦點(diǎn)和失去焦點(diǎn)的方法
- JavaScript(js)設(shè)置默認(rèn)輸入焦點(diǎn)(focus)
- js 獲取坐標(biāo) 通過(guò)JS得到當(dāng)前焦點(diǎn)(鼠標(biāo))的坐標(biāo)屬性
- JS焦點(diǎn)圖切換,上下翻轉(zhuǎn)
- 使用JS取得焦點(diǎn)(focus)元素代碼
- 獲取焦點(diǎn)時(shí),利用js定時(shí)器設(shè)定時(shí)間執(zhí)行動(dòng)作
- 鼠標(biāo)焦點(diǎn)離開文本框時(shí)驗(yàn)證的js代碼
- 比較炫的圖片播放器 js 焦點(diǎn)效果代碼
- JavaScript 關(guān)于元素獲取焦點(diǎn)(隱藏元素與div)
- 詳細(xì)總結(jié)Javascript中的焦點(diǎn)管理
相關(guān)文章
js實(shí)現(xiàn)textarea限制輸入字?jǐn)?shù)
本文主要介紹了js實(shí)現(xiàn)textarea限制輸入字?jǐn)?shù)的原理與方法。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-02-02
JavaScript使用docx-preview和mammoth預(yù)覽Docx
這篇文章主要為大家詳細(xì)介紹了兩個(gè)庫(kù),即docx-preview和mammoth,利用它們,你就能在瀏覽器中完美預(yù)覽 Word 文檔,甚至連表格樣式,頁(yè)眉頁(yè)腳都原汁原味地呈現(xiàn)出來(lái),下面我們來(lái)看看具體使用步驟吧2025-04-04
JS基于FileSaver.js插件實(shí)現(xiàn)文件保存功能示例
這篇文章主要介紹了JS基于FileSaver.js插件實(shí)現(xiàn)文件保存功能,結(jié)合實(shí)例形式演示了FileSaver.js插件的具體使用技巧,需要的朋友可以參考下2016-12-12
完美實(shí)現(xiàn)js拖拽效果 return false用法詳解
這篇文章主要為大家詳細(xì)介紹了完美實(shí)現(xiàn)js拖拽效果的代碼,一起學(xué)習(xí)return false的用法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07
layui.use模塊外部使用其內(nèi)部定義的js封裝函數(shù)方法
今天小編就為大家分享一篇layui.use模塊外部使用其內(nèi)部定義的js封裝函數(shù)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
javaScript動(dòng)態(tài)添加Li元素的實(shí)例
下面小編就為大家分享一篇javaScript動(dòng)態(tài)添加Li元素的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02
javascript刪除數(shù)組元素并且數(shù)組長(zhǎng)度減小的簡(jiǎn)單實(shí)例
本篇文章主要是對(duì)javascript刪除數(shù)組元素并且數(shù)組長(zhǎng)度減小的簡(jiǎn)單實(shí)例進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-02-02
原生JS實(shí)現(xiàn) MUI導(dǎo)航欄透明漸變效果
透明漸變導(dǎo)航是一種解決滾動(dòng)條通頂?shù)淖兺ǚ桨浮_@篇文章主要介紹了原生JS實(shí)現(xiàn) MUI導(dǎo)航欄透明漸變效果,需要的朋友可以參考下2017-11-11
layer.alert回調(diào)函數(shù)執(zhí)行關(guān)閉彈窗的實(shí)例
今天小編就為大家分享一篇layer.alert回調(diào)函數(shù)執(zhí)行關(guān)閉彈窗的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09

