onfocus 事件
定義和用法
onfocus 事件在元素獲得焦點時發生。
onfocus 事件最常與 <input>、<select> 和 <a> 一起使用。
提示: onfocus 事件與 onblur 事件相反。
提示: onfocus 事件類似于 onfocusin 事件。主要區別在于 onfocus 事件不會冒泡。因此,如果您想確定一個元素或其子元素是否獲得焦點,可使用 onfocusin 事件。但是,您可以通過對 onfocus 事件使用 addEventListener() 方法的 useCapture 參數來實現這一點。
語法
在 HTML 中:
<element onfocus="myScript">
在 JavaScript 中:
object.onfocus = function(){myScript};
在 JavaScript 中,使用 addEventListener() 方法:
object.addEventListener("focus", myScript);
注釋:Internet Explorer 8 或更早的版本不支持 addEventListener() 方法。
技術細節
冒泡: | 不支持 |
---|---|
可取消: | 不支持 |
事件類型: | FocusEvent |
支持的 HTML 標簽: | 所有 HTML 元素,除了:<base>, <bdo>, <br>, <head>, <html>, <iframe>, <meta>, <param>, <script>, <style> 以及 <title> |
DOM 版本: | Level 2 Events |
瀏覽器支持
事件 | Chrome | IE | Firefox | Safari | Opera |
---|---|---|---|---|---|
onfocus | 支持 | 支持 | 支持 | 支持 | 支持 |
更多實例
例子 2
將 "onfocus" 與 "onblur" 事件一起使用:
<input type="text" onfocus="focusFunction()" onblur="blurFunction()">
例子 3
清空獲得焦點的輸入字段:
<!-- 當輸入字段獲得焦點時,將其當前值替換為空字符串 --> <input type="text" onfocus="this.value=''" value="Blabla">
例子 4
事件委托:將 addEventListener() 的 useCapture 參數設置為 true:
<form id="myForm"> <input type="text" id="myInput"> </form> <script> var x = document.getElementById("myForm"); x.addEventListener("focus", myFocusFunction, true); x.addEventListener("blur", myBlurFunction, true); function myFocusFunction() { document.getElementById("myInput").style.backgroundColor = "yellow"; } function myBlurFunction() { document.getElementById("myInput").style.backgroundColor = ""; } </script>
例子 5
事件委托:使用 focusin 事件(Firefox 不支持):
<form id="myForm"> <input type="text" id="myInput"> </form> <script> var x = document.getElementById("myForm"); x.addEventListener("focusin", myFocusFunction); x.addEventListener("focusout", myBlurFunction); function myFocusFunction() { document.getElementById("myInput").style.backgroundColor = "yellow"; } function myBlurFunction() { document.getElementById("myInput").style.backgroundColor = ""; } </script>