onfocus 事件

定義和用法

onfocus 事件在元素獲得焦點時發生。

onfocus 事件最常與 <input>、<select> 和 <a> 一起使用。

提示: onfocus 事件與 onblur 事件相反。

提示: onfocus 事件類似于 onfocusin 事件。主要區別在于 onfocus 事件不會冒泡。因此,如果您想確定一個元素或其子元素是否獲得焦點,可使用 onfocusin 事件。但是,您可以通過對 onfocus 事件使用 addEventListener() 方法useCapture 參數來實現這一點。

實例

例子 1

當輸入字段獲得焦點時執行 JavaScript:

<input type="text" onfocus="myFunction()">

親自試一試

頁面下方有更多 TIY 實例。

語法

在 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>

親自試一試