oninvalid 事件

定义和用法

当可提交的 <input> 元素无效时,会发生 oninvalid 事件。

例如,如果设置了 required 属性,并且字段为空,则输入字段无效(required 属性指定输入字段必须在提交表单之前填写)。

实例

例子 1

如果输入字段无效,则提示一些文本:

<input type="text" oninvalid="alert('You must fill out the form!');" required>

亲自试一试

页面下方有更多 TIY 实例。

语法

在 HTML 中:

<element oninvalid="myScript">

亲自试一试

在 JavaScript 中:

object.oninvalid = function(){myScript};

亲自试一试

在 JavaScript 中,使用 addEventListener() 方法:

object.addEventListener("invalid", myScript);

亲自试一试

注释:Internet Explorer 8 或更早的版本不支持 addEventListener() 方法

技术细节

冒泡: 不支持
可取消: 支持
事件类型: Event
支持的 HTML 标签: <input>
DOM 版本: Level 3 Events

浏览器支持

表中的数字注明了完全支持该事件的首个浏览器版本。

事件 Chrome IE Firefox Safari Opera
oninvalid 支持 10.0 支持 支持 支持

更多实例

例子 2

如果输入字段包含少于 6 个字符,则提示一些文本:

Name: <input type="text" id="myInput" name="fname" pattern=".{6,}" required>

<script>
document.getElementById("myInput").addEventListener("invalid", myFunction);

function myFunction() {
  alert("Must contain 6 or more characters");
}
</script>

亲自试一试

例子 3

如果输入字段包含小于 2 或大于 5 的数字,则提示一些文本:

Number: <input type="number" id="myInput" name="quantity" min="2" max="5" required>

<script>
document.getElementById("myInput").addEventListener("invalid", myFunction);

function myFunction() {
  alert("You must pick a number between 2 and 5. You chose: " + this.value);
}
</script>

亲自试一试

相关页面

JavaScript 教程:JavaScript 表单