国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

有效的捕獲JavaScript焦點的方法小結(jié)

2019-11-21 01:06:05
字體:
供稿:網(wǎng)友
1. 設(shè)置元素可獲得焦點以監(jiān)聽鍵盤事件
元素聚焦最大好處就是可允許發(fā)送鍵盤事件,HTML很多元素默認(rèn)就有可聚焦,如form表單元素,a錨鏈接等,但大部份默認(rèn)是不能聚焦的。要使得元素能夠聚焦,可以在HTML代碼或JavaScript腳本中實現(xiàn)。
html:
復(fù)制代碼 代碼如下:

<div tabIndex="0" style="height:100px;width:100px; background:red;"></div>

JavaScript:
oDiv.tabIndex = 0;
其中tabIndex是TAB鍵的導(dǎo)航順序,可有正,負(fù)或零。
當(dāng)元素獲得焦點時會有邊框指示,如果想不顯示這個邊框,可以
html:
復(fù)制代碼 代碼如下:

<div tabIndex="0" hidefocus="on" ></div>

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

oDiv.onmousedown = function(){
document.getElementById('ipt').focus();
};

參考瀏覽器內(nèi)核處理流程圖:

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

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

oDiv.onmousedown = function(){
setTimeout(function(){
document.getElementById('ipt').focus();
}, 0);
};

由上可知,最后那個毫秒數(shù)即使設(shè)為0也沒關(guān)系.

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

try{
element.focus();
}catch(e){}

到此,與JavaScript焦點捕獲相關(guān)的問題討論就完成了.
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 屯留县| 扎鲁特旗| 丘北县| 吉木萨尔县| 通海县| 威海市| 马公市| 温泉县| 建德市| 武夷山市| 松桃| 盐津县| 新乡县| 漯河市| 尼勒克县| 沧源| 新河县| 赤壁市| 辽阳市| 麟游县| 苍南县| 洛阳市| 凤庆县| 洮南市| 济宁市| 民乐县| 南投市| 兴海县| 拜城县| 高阳县| 崇左市| 扶沟县| 浦县| 湖州市| 孝感市| 弋阳县| 诸城市| 康保县| 南华县| 波密县| 湘阴县|