介绍
HTML中的onfocus
和onblur
是一些常用的属性,它们允许您指定在用户对元素执行焦点(单击或Tab到)时或用户从焦点移动到元素之外时要执行的JavaScript代码。
onfocus
和onblur
属性的使用非常广泛,它们通常用于创建交互性表单或高级网页。
onfocus属性
onfocus
属性允许您指定当用户将焦点移动到一个元素上时要执行的JavaScript代码。例如,当用户在一个文本框中单击或将光标移动到文本框中时,可以使用onfocus
属性来触发一些JavaScript代码。
下面是一个简单的onfocus
属性的示例:
<input type="text" onfocus="alert('Hello World!')">
在上面的示例中,当用户将光标移动到文本输入框上时,将显示一个警告框,其中包含文本“Hello World!”。
onblur属性
onblur
属性与onfocus
属性类似,但它会在用户将焦点从元素移动到窗口中的另一个元素时触发。例如,当用户从一个文本框中移动到另一个输入框或单击窗口中的其他区域时,可以使用onblur
属性来触发一些JavaScript代码。
下面是一个简单的onblur
属性的示例:
<input type="text" onblur="alert('Goodbye World!')">
在上面的示例中,当用户将焦点从文本输入框中移开时,将显示一个警告框,其中包含文本“Goodbye World!”。
使用示例
下面是一个使用onfocus
和onblur
属性的示例,以便在文本框中包含说明文本时在用户输入内容时自动删除说明文本:
<input type="text" onfocus="if(this.value == 'Enter name here') this.value='';"
onblur="if(this.value == '') this.value='Enter name here';"
value="Enter name here">
在上面的示例中,当用户点击文本框(使用 onfocus
)时,如果文本框的默认内容为“Enter name here”,则将清除文本框中的内容。如果文本框中没有任何内容(使用 onblur
)时,将重新添加“Enter name here”规则。
总结
在HTML中,onfocus
和onblur
属性是一些非常有用的属性,它们允许您指定在用户对元素执行焦点(单击或Tab到)时或用户从焦点移动到元素之外时要执行的JavaScript代码。您可以在表单验证,文本框输入提示,和添加默认值等方面使用这些属性,以创建交互式,动态的网页。
当然,这些属性在不同浏览器上的表现不一样,有些用户也会选择禁用JavaScript。因此,在使用这些属性时,最好不要使这些属性成为表单中的必要部分,而是应该将这些属性视为用户体验的一种补充。