189 8069 5689

vuejs中有哪些事件

这篇文章主要介绍了vuejs中有哪些事件,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

桑日网站制作公司哪家好,找成都创新互联公司!从网页设计、网站建设、微信开发、APP开发、成都响应式网站建设公司等网站项目制作,到程序开发,运营维护。成都创新互联公司于2013年开始到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选成都创新互联公司

vuejs中的事件有:focus、blur、click(单击)、dblclick、contextmen、mousemove、mouseover、mouseout、mouseup、keydown 、keyup、select、wheel等等。

本教程操作环境:windows7系统、vue2.9.6版,DELL G3电脑。

Event Handler 事件处理

Vuejs中的事件处理非常强大, 也非常重要。 我们一定要学好它。

Event Handler 之所以会被Vuejs放到很高的地位,是基于这样的考虑:

  • 把跟事件相关的代码独立的写出来, 非常容易定位各种逻辑, 维护起来方便。

  • event handler 被独立出来之后, 页面的DOM元素看起来就会很简单。 容易理解。

  • 当一个页面被关掉时,对应的ViewModel也会被回收。那么该页面定义的各种 event handler 也会被一并垃圾回收。 不会造成内存溢出。

支持的Event

我们在前面曾经看到过 v-on:click, 那么,都有哪些事件可以被v-on所支持呢?

只要是标准的HTML定义的Event, 都是被Vuejs支持的。

  • focus (元素获得焦点)

  • blur (元素失去焦点)

  • click (单击 鼠标左键)

  • dblclick (双击鼠标左键)

  • contextmenu (单机鼠标右键)

  • mouseover (指针移到有事件监听的元素或者它的子元素内)

  • mouseout (指针移出元素,或者移到它的子元素上)

  • keydown (键盘动作: 按下任意键)

  • keyup (键盘动作: 释放任意键)

所有HTML标准事件:https://developer.mozilla.org/zh-CN/docs/Web/Events

例:

vuejs中有哪些事件

vuejs中有哪些事件

vuejs中有哪些事件

总共定义了 162个标准事件, 和 几十个非标准事件,以及 Mozilla的特定事件。 如下图所示:

vuejs中有哪些事件
我们不用全部都记住,通常在日常开发中,只有不到20个是最常见的event.

使用 v-on 进行事件的绑定

我们可以认为,几乎所有的事件,都是由 v-on 这个 directive 来驱动的。 所以,本节会对 v-on 有更加详尽的说明。

1. 在 v-on 中使用变量

如下面代码所示,可以在 v-on 中引用变量:



	


	
		您点击了: {% raw %}{{{% endraw %} count }} 次
		
 + 1

上面的代码,用浏览器打开后, 点击 按钮, 就可以看到 count 这个变量会随之 +1. 如下图所示:

vuejs中有哪些事件

2. 在 v-on 中使用方法名

上面的例子,也可以按照下面的写法来实现:



	


	
		您点击了:{% raw %}{{{% endraw %} count }} 次
		
  + 1 

可以看到,在 v-on:click='increase_count' 中, increase_count 就是一个方法名。

3. 在v-on 中使用方法名 + 参数

我们也可以直接使用 v-on:click='some_function("your_parameter")' 这样的写法,如 下面的例子所示:



	


	
		{% raw %}{{{% endraw %} message }}
		
 跟我打个招呼~ 

使用浏览器打开后,点击按钮,就可以看到下图所示:
vuejs中有哪些事件

4. 重新设计按钮的逻辑

我们在实际开发中,往往会遇到这样的情况: 点击某个按钮,或者触发某个事件后,希望按钮的默认状态。

最典型的例子: 提交表单(

)的时候,我们希望先对该表单进行验证。 如果验证不通过,该表单就不要提交。

这个时候,如果希望表单不要提交,我们就要让 这个 submit 按钮,不要有下一步的动作。 在所有的开发语言当中,都会有一个对应的方法,叫做: “preventDefault
(停止默认动作)

我们看这个例子:



	


	

		请输入您想打开的网址,   	
判断规则是: 
1. 务必以 "http://"开头 
2. 不能是空字符串
 

 点我确定 

上面的代码中,可以看到,我们定义了一个变量: url. 并且通过代码:

点我确定 做了两件事情:

validate方法中,我们是这样定义的: 先验证是否符合规则。 如果符合,放行,会继续触发 元素的默认动作(让浏览器发生跳转) 。 否则的
话,会弹出一个 “alert” 提示框。

用浏览器打开这段代码,可以看到下图所示:
vuejs中有哪些事件
我们先输入一个合法的地址: http://baidu.com , 可以看到,点击后,页面发生了跳转。 跳转到了百度。

我们再输入一个 “不合法”的地址: https://baidu.com 注意: 该地址不是以 “http://” 开头,所以我们的vuejs 代码不会让它放行。

如下图所示:
vuejs中有哪些事件
进一步观察,页面也不会跳转(很好的解释了 这个时候
标签点了也不起作用)

5. Event Modifiers 事件修饰语

我们很多时候,希望把代码写的优雅一些。 使用传统的方式,可能会把代码写的很臃肿。 如果某个元素在不同的event下有不同的表现,那么代码看起来就会有
很多个 if ...else ... 这样的分支。

所以, Vuejs 提供了 “Event Modifiers”。

例如,我们可以把上面的例子略加修改:



	


	

		请输入您想打开的网址,   	
判断规则是: 
1. 务必以 "http://"开头 
2. 不能是空字符串
 

 点我确定 

可以看出,上面的代码的核心是:

 点我确定 

methods: {
	validate: function(event){
		if(this.url.length == 0 || this.url.indexOf('http://') != 0){
			if(event){
				event.preventDefault()
			}   
		}
	},
	show_message: function(){
		alert("您输入的网址不符合规则。 无法跳转")
	}
}

先是在 中定义了两个 click 事件,一个是 click, 一个是 click.prevent. 后者表示,如果该元素的click 事件被 阻止了的话, 应该触发什么动作。

然后,在 methods 代码段中,专门定义了 show_message , 用来给 click.prevent 所使用。

上面的代码运行起来,跟前一个例子是一模一样的。 只是抽象分类的程度更高了一些。 在复杂的项目中有用处。

这样的 “event modifier”,有这些:

以上的 “event modifier” 也可以连接起来使用。 例如: v-on:click.prevent.self

6. Key Modifiers 按键修饰语

Vuejs 也很贴心的提供了 Key Modifiers, 也就是一种支持键盘事件的快捷方法。 我们看下面的例子:



	


	
		输入完毕后,按下回车键,就会
触发 "show_message" 事件~  

可以看到,在上面的代码中, v-on:keyup.enter="show_message" 元素定义了事件,该事件对应了 “回车键”。
(严格的说,是回车键被按下后,松开弹起来的那一刻)

我们用浏览器打开上面的代码对应的文件,输入一段文字,按回车,就可以看到事件已经被触发了。

Vuejs 总共支持下面这些 Key modifiers:

随着 Vuejs 版本的不断迭代和更新,越来越多的 Key modifiers 被添加了进来, 例如 page down, ctrl

感谢你能够认真阅读完这篇文章,希望小编分享的“vuejs中有哪些事件”这篇文章对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,更多相关知识等着你来学习!


网页标题:vuejs中有哪些事件
本文来源:
http://gzruizhi.cn/article/iedjpo.html

其他资讯