欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2009年10月08日 17:58:58   作者:  
閱讀本文可理解并解決以下問題 設(shè)置元素可獲得焦點(diǎn)以監(jiān)聽鍵盤事件 某個(gè)元素明明設(shè)置了聚焦卻沒效果 聚焦時(shí)拋出異常的
1. 設(shè)置元素可獲得焦點(diǎn)以監(jiān)聽鍵盤事件
元素聚焦最大好處就是可允許發(fā)送鍵盤事件,HTML很多元素默認(rèn)就有可聚焦,如form表單元素,a錨鏈接等,但大部份默認(rèn)是不能聚焦的。要使得元素能夠聚焦,可以在HTML代碼或JavaScript腳本中實(shí)現(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)元素獲得焦點(diǎn)時(shí)會(huì)有邊框指示,如果想不顯示這個(gè)邊框,可以
html:
復(fù)制代碼 代碼如下:

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

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

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ù)中的聚焦變得無效.

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

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

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

3. 聚焦時(shí)拋出異常的
在IE中,當(dāng)元素不可見時(shí)如果聚焦的話,會(huì)拋出一個(gè)異常,因?yàn)樵诤芏鄳?yīng)用中我們往往不再對(duì)元素是否不可見作測試就聚焦了,因?yàn)榧词惯@樣也沒什么問題(誰說不可見元素就不可以聚焦的?)..所以,在IE下可用try{}catch(){}來忽略這個(gè)異常.
復(fù)制代碼 代碼如下:

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

到此,與JavaScript焦點(diǎn)捕獲相關(guān)的問題討論就完成了.

相關(guān)文章

  • js復(fù)制文本到粘貼板(Clipboard.writeText())

    js復(fù)制文本到粘貼板(Clipboard.writeText())

    這篇文章主要介紹了js復(fù)制文本到粘貼板(Clipboard.writeText()),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • TS中最常見的聲明合并(接口合并)

    TS中最常見的聲明合并(接口合并)

    這篇文章主要介紹了TS中最常見的聲明合并:接口合并,TS中的聲明合并,指的就是編譯器會(huì)針對(duì)同名的聲明合并為一個(gè)聲明,合并后的聲明會(huì)同時(shí)擁有原先兩個(gè)或多個(gè)聲明的特性,接口的合并也是一樣,它會(huì)將雙方的成員放到一個(gè)同名的接口里,更多詳細(xì)內(nèi)容請(qǐng)參考下面文章內(nèi)容

    2021-12-12
  • 鼠標(biāo)移入移出事件改變圖片的分辨率的兩種方法

    鼠標(biāo)移入移出事件改變圖片的分辨率的兩種方法

    做一個(gè)鼠標(biāo)移入移出圖片事件,首先是改變分辨率的兩種方法,鼠標(biāo)移入圖片和移出圖片的分辨率不同,具體實(shí)現(xiàn)如下,感興趣的朋友可以參考下
    2013-12-12
  • 圖解js圖片輪播效果

    圖解js圖片輪播效果

    這篇文章主要以圖片展示的方式向大家講解了js圖片輪播效果的實(shí)現(xiàn)方法,對(duì)圖片輪播實(shí)現(xiàn)原理進(jìn)行了詳細(xì)介紹,感興趣的朋友可以參考一下
    2015-12-12
  • JavaScript判斷變量名是否存在數(shù)組中的實(shí)例

    JavaScript判斷變量名是否存在數(shù)組中的實(shí)例

    下面小編就為大家分享一篇JavaScript判斷變量名是否存在數(shù)組中的實(shí)例,具有很的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • 快速上手uni-simple-router

    快速上手uni-simple-router

    這篇文章主要介紹了uni-simple-router,本文通過實(shí)例代碼給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-11-11
  • 微信小程序使用toast消息對(duì)話框提示用戶忘記輸入用戶名或密碼功能【附源碼下載】

    微信小程序使用toast消息對(duì)話框提示用戶忘記輸入用戶名或密碼功能【附源碼下載】

    這篇文章主要介紹了微信小程序使用toast消息對(duì)話框提示用戶忘記輸入用戶名或密碼功能,結(jié)合實(shí)例形式詳細(xì)分析了toast組件實(shí)現(xiàn)消息提示功能的相關(guān)操作技巧,并附帶源碼供讀者下載參考,需要的朋友可以參考下
    2017-12-12
  • 淺談?dòng)肳ebpack路徑壓縮圖片上傳尺寸獲取的問題

    淺談?dòng)肳ebpack路徑壓縮圖片上傳尺寸獲取的問題

    下面小編就為大家分享一篇淺談?dòng)肳ebpack路徑壓縮圖片上傳尺寸獲取的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • 淺談通過JS攔截 pushState和replaceState事件

    淺談通過JS攔截 pushState和replaceState事件

    下面小編就為大家?guī)硪黄獪\談通過JS攔截 pushState和replaceState事件。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-07-07
  • safari,opera嵌入iframe頁面cookie讀取問題解決方法

    safari,opera嵌入iframe頁面cookie讀取問題解決方法

    最近做的合作網(wǎng)站嵌入到對(duì)方的iframe中去,在safari,opera和有些版本的搜狗瀏覽器(內(nèi)核版本原因)中不能讀到cookie。
    2010-06-06

最新評(píng)論