onfocusin 事件

事件对象参考手册 事件对象

在输入字段(input)即将获取焦点时执行 JavaScript:

输入您的名字: <input type="text" onfocusin="myFunction(this)">
<p>当 input 输入框获取焦点时,JavaScript 函数将被触发,并修改背景颜色。 </p>
<p><strong>注意:</strong> Firefox 浏览器不支持 onfocusin 事件。</p>
<script>
  function myFunction(x) {
    x.style.background = "yellow";
  }
</script>

尝试一下 »

本章节底部还有更多实例。


定义和用法

onfocusin 事件在一个元素即将获得焦点时触发。

提示: onfocusin 事件类似于 onfocus 事件。 主要的区别是 onfocus 事件不支持冒泡。因此,如果你想知道元素或者其子元素是否获取焦点,需要使用 onfocusin 事件。

提示: 虽然 Firefox 浏览器不支持 onfocusin 事件, 但你可以通过使用 onfocus (使用addEventListener()方法的可选参数 useCapture)的捕获监听事件来查看元素或其子元素是否获取焦点。

提示: onfocusin 事件的相反事件是 onfocusout 事件。


浏览器支持

事件
onfocusin Yes Yes 不支持 Yes Yes

注意: 在 Chrome, Safari 和 Opera 15+ 浏览器中使用 HTML DOM 语法的 onfocusin 事件可能无法正常工作。 但是,他作为一个 HTML 元素,通过使用 addEventListener() 方法可以正常工作。


语法

HTML 中:

<element onfocusin="myScript">
<p>该实例演示了如何向 input 元素添加 "onfocusin" 事件。</p>

输入您的名字: <input type="text" id="fname" onfocusin="myFunction()">
<p><strong>注意:</strong> Firefox 浏览器不支持 onfocusin 事件。</p>
<script>
  function myFunction() {
    document.getElementById("fname").style.backgroundColor = "red";
  }
</script>

尝试一下 »

JavaScript (Chrome, Safari 和 Opera 15+ 可能无法正常工作) 中:

object.onfocusin = function() {
  myScript
};
<p>该实例演示了如何使用 HTML DOM 向 input 元素添加 "onfocusin" 事件。</p>
输入您的名字: <input type="text" id="fname">
<p><strong>注意:</strong> Firefox 浏览器不支持 onfocusin 事件。</p>
<p><strong>注意:</strong> 该实例可能无法在 Chrome, Safari 和 Opera 15+ 中工作。</p>
<script>
  document.getElementById("fname").onfocusin = function() {
    myFunction()
  };

  function myFunction() {
    document.getElementById("fname").style.backgroundColor = "red";
  }
</script>

尝试一下 »

JavaScript 中, 使用 addEventListener() 方法:

object.addEventListener("focusin", myScript);
<p>该实例演示了如何使用 addEventListener() 方法向 input 元素添加 "onfocusin" 事件。</p>
输入您的名字: <input type="text" id="fname">
<p><strong>注意:</strong> Firefox 浏览器不支持 onfocusin 事件。</p>
<script>
  document.getElementById("fname").addEventListener("focusin", myFunction);

  function myFunction() {
    document.getElementById("fname").style.backgroundColor = "red";
  }
</script>

尝试一下 »

注意: Internet Explorer 8 及更早 IE 版本不支持 addEventListener() 方法。


技术细节

是否支持冒泡: Yes
是否可以取消: No
事件类型: FocusEvent
支持的 HTML 标签: 所有 HTML 元素,除了: <base>, <bdo>, <br>, <head>, <html>, <iframe>, <meta>, <param>, <script>, <style>, 和 <title>

更多实例

一起使用 "onfocusin" 和 "onfocusout" 事件:

<p>当在 input 框输入时(获取焦点),一个函数将被触发,并设置背景颜色。当离开 input 输入框时(失去焦点),另一个函数将被触发并设置对应的背景颜色。</p>
输入您的名字: <input type="text" id="myInput" onfocusin="focusFunction()" onfocusout="blurFunction()">
<p><strong>注意:</strong> Firefox 浏览器不支持 onfocusin 事件。</p>
<script>
  // 获取焦点 = 修改输入框的背景演示为黄色
  function focusFunction() {
    document.getElementById("myInput").style.background = "yellow";
  }
  // 失去焦点 = 修改输入框的背景演示为红色
  function blurFunction() {
    document.getElementById("myInput").style.background = "red";
  }
</script>

尝试一下 »


事件委托:设置 addEventListener() 的 useCapture 参数为 true (用于获取焦点和失去焦点):

<p>当在 input 框输入时(获取焦点,FORM表单是子元素),一个函数将被触发,并设置背景颜色为黄色。当离开 input 输入框时(失去焦点),另一个函数将被触发并移除背景颜色。</p>
<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>

尝试一下 »


事件委托:使用 focusin 事件 ( Firefox 浏览器不支持):

<p>当在 input 框输入时(获取焦点,FORM表单是子元素),一个函数将被触发,并设置背景颜色为黄色。当离开 input 输入框时(失去焦点),另一个函数将被触发并移除背景颜色。</p>
<form id="myForm">
  <input type="text" id="myInput">
</form>
<p><strong>注意:</strong> Firefox 浏览器不支持 onfocusin 事件。</p>
<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>

尝试一下 »


事件对象参考手册 事件对象