addeventlistener事件参数_【JavaScript 教程】事件——表单事件

f60a61fba48bc6c19dbb08181a6a99f7.png

作者 | 阮一峰

1、表单事件的种类

1.1、input 事件

input事件当的值发生变化时触发。对于复选框()或单选框(),用户改变选项时,也会触发这个事件。另外,对于打开contenteditable属性的元素,只要值发生变化,也会触发input事件。

input事件的一个特点,就是会连续触发,比如用户每按下一次按键,就会触发一次input事件。

input事件对象继承了InputEvent接口。

该事件跟change事件很像,不同之处在于input事件在元素的值发生变化后立即发生,而change在元素失去焦点时发生,而内容此时可能已经变化多次。也就是说,如果有连续变化,input事件会触发多次,而change事件只在失去焦点时触发一次。

下面是元素的例子。

/* HTML 代码如下123
*/

上面代码中,改变下拉框选项时,会触发input事件,从而执行回调函数inputHandler

1.2、select 事件

select事件当在里面选中文本时触发。

// HTML 代码如下

选中的文本可以通过event.target元素的selectionDirectionselectionEndselectionStartvalue属性拿到。

1.3、change 事件

change事件当的值发生变化时触发。它与input事件的最大不同,就是不会连续触发,只有当全部修改完成时才会触发,另一方面input事件必然伴随change事件。具体来说,分成以下几种情况。

  • 激活单选框(radio)或复选框(checkbox)时触发。

  • 用户提交时触发。比如,从下列列表(select)完成选择,在日期或文件输入框完成选择。

  • 当文本框或元素的值发生改变,并且丧失焦点时触发。

下面是一个例子。

// HTML 代码如下

如果比较一下上面input事件的例子,你会发现对于元素来说,inputchange事件基本是等价的。

1.4、invalid 事件

用户提交表单时,如果表单元素的值不满足校验条件,就会触发invalid事件。

<form>

上面代码中,输入框是必填的。如果不填,用户点击按钮提交时,就会触发输入框的invalid事件,导致提交被取消。

1.5、reset 事件,submit 事件

这两个事件发生在表单对象上,而不是发生在表单的成员上。

reset事件当表单重置(所有表单成员变回默认值)时触发。

submit事件当表单数据向服务器提交时触发。注意,submit事件的发生对象是元素,而不是元素,因为提交的是表单,而不是按钮。

2、InputEvent 接口

InputEvent接口主要用来描述input事件的实例。该接口继承了Event接口,还定义了一些自己的实例属性和实例方法。

浏览器原生提供InputEvent()构造函数,用来生成实例对象。

new InputEvent(type, options)

InputEvent构造函数可以接受两个参数。第一个参数是字符串,表示事件名称,该参数是必需的。第二个参数是一个配置对象,用来设置事件实例的属性,该参数是可选的。配置对象的字段除了Event构造函数的配置属性,还可以设置下面的字段,这些字段都是可选的。

  • inputType:字符串,表示发生变更的类型(详见下文)。

  • data:字符串,表示插入的字符串。如果没有插入的字符串(比如删除操作),则返回null或空字符串。

  • dataTransfer:返回一个 DataTransfer 对象实例,该属性通常只在输入框接受富文本输入时有效。

InputEvent的实例属性主要就是上面三个属性,这三个实例属性都是只读的。

(1)InputEvent.data

InputEvent.data属性返回一个字符串,表示变动的内容。

// HTML 代码如下

上面代码中,如果手动在输入框里面输入abc,控制台会先输出a,再在下一行输出b,再在下一行输出c。然后选中abc,一次性将它们删除,控制台会输出null或一个空字符串。

(2)InputEvent.inputType

InputEvent.inputType属性返回一个字符串,表示字符串发生变更的类型。

对于常见情况,Chrome 浏览器的返回值如下。完整列表可以参考文档。

  • 手动插入文本:insertText

  • 粘贴插入文本:insertFromPaste

  • 向后删除:deleteContentBackward

  • 向前删除:deleteContentForward

(3)InputEvent.dataTransfer

InputEvent.dataTransfer属性返回一个 DataTransfer 实例。该属性只在文本框接受粘贴内容(insertFromPaste)或拖拽内容(insertFromDrop)时才有效。

6c5144c309aed97544c9e47a043bd3ef.png

7a6349a956fdf8e359effb8a4720cda4.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值