Vue 方法与事件处理器
方法与事件处理器
方法处理器
可以用 v-on
指令监听 DOM 事件:
<div id="example"><button v-on:click="greet">Greet</button> </div>
我们绑定了一个单击事件处理器到一个方法 greet
。下面在 Vue 实例中定义这个方法:
var vm = new Vue({el: '#example',data: {name: 'Vue.js'},// 在 `methods` 对象中定义方法 methods: {greet: function (event) {// 方法内 `this` 指向 vmalert('Hello ' + this.name + '!')// `event` 是原生 DOM 事件 alert(event.target.tagName)}} })// 也可以在 JavaScript 代码中调用方法 vm.greet() // -> 'Hello Vue.js!'
内联语句处理器
除了直接绑定到一个方法,也可以用内联 JavaScript 语句:
<div id="example-2"><button v-on:click="say('hi')">Say Hi</button><button v-on:click="say('what')">Say What</button> </div>new Vue({el: '#example-2',methods: {say: function (msg) {alert(msg)}} })
类似于内联表达式,事件处理器限制为一个语句。
有时也需要在内联语句处理器中访问原生 DOM 事件。可以用特殊变量 $event
把它传入方法:
<button v-on:click="say('hello!', $event)">Submit</button>
// ... methods: {say: function (msg, event) {// 现在我们可以访问原生事件对象 event.preventDefault()} }
事件修饰符
在事件处理器中经常需要调用 event.preventDefault()
或 event.stopPropagation()
。尽管我们在方法内可以轻松做到,不过让方法是纯粹的数据逻辑而不处理 DOM 事件细节会更好。
为了解决这个问题,Vue.js 为 v-on
提供两个 事件修饰符:.prevent
与 .stop
。你是否还记得修饰符是点号打头的指令后缀?
<!-- 阻止单击事件冒泡 --> <a v-on:click.stop="doThis"></a><!-- 提交事件不再重载页面 --> <form v-on:submit.prevent="onSubmit"></form><!-- 修饰符可以串联 --> <a v-on:click.stop.prevent="doThat"><!-- 只有修饰符 --> <form v-on:submit.prevent></form>
1.0.16 添加了两个额外的修饰符:
<!-- 添加事件侦听器时使用 capture 模式 --> <div v-on:click.capture="doThis">...</div><!-- 只当事件在该元素本身(而不是子元素)触发时触发回调 --> <div v-on:click.self="doThat">...</div>
按键修饰符
在监听键盘事件时,我们经常需要检测 keyCode。Vue.js 允许为 v-on
添加按键修饰符:
<!-- 只有在 keyCode 是 13 时调用 vm.submit() --> <input v-on:keyup.13="submit">
记住所有的 keyCode 比较困难,Vue.js 为最常用的按键提供别名:
<!-- 同上 --> <input v-on:keyup.enter="submit"><!-- 缩写语法 --> <input @keyup.enter="submit">
全部的按键别名:
enter tab delete esc space up down left right
1.0.8+: 支持单字母按键别名。
1.0.17+: 可以自定义按键别名:
// 可以使用 @keyup.f1 Vue.directive('on').keyCodes.f1 = 112
为什么在 HTML 中监听事件?
你可能注意到这种事件监听的方式违背了传统理念 “separation of concern”。不必担心,因为所有的 Vue.js 事件处理方法和表达式都严格绑定在当前视图的 ViewModel 上,它不会导致任何维护困难。实际上,使用 v-on
有几个好处:
扫一眼 HTML 模板便能轻松定位在 JavaScript 代码里对应的方法。
因为你无须在 JavaScript 里手动绑定事件,你的 ViewModel 代码可以是非常纯粹的逻辑,和 DOM 完全解耦,更易于测试。
当一个 ViewModel 被销毁时,所有的事件处理器都会自动被删除。你无须担心如何自己清理它们。
转载于:https://www.cnblogs.com/jiangxiaobo/p/5425000.html
Vue 方法与事件处理器相关推荐
- Vue基础之事件处理器
监听事件: 可以用 v-on 指令监听 DOM 事件来触发一些 JavaScript 代码 示例 方法事件处理器: 许多事件处理的逻辑都很复杂,所以直接把 JavaScript 代码写在 v-on 指 ...
- vue样式绑定与事件处理器的基本使用
目录 Vue.js 样式绑定 Vue.js 事件处理器 事件修饰符 Vue.js 样式绑定
- 08.vue.js实战笔记(计算属性、v-bind及class和style的绑定、内置指令、方法与事件)
1.计算属性 所有的计算属性都以函数的形式写在vue实例的computed选项内,最终返回计算后的结果 <!DOCTYPE html> <html lang="en&quo ...
- Vue模块语法下(事件处理器自定义组件组件通信)
文章目录 一.事件处理器 事件修饰符 二.自定义组件 组件简介 全局和局 ...
- 前端MVC Vue2学习总结(四)——条件渲染、列表渲染、事件处理器
一.条件渲染 1.1.v-if 在字符串模板中,如 Handlebars ,我们得像这样写一个条件块: <!-- Handlebars 模板 --> {{#if ok}}<h1> ...
- vue学习:事件传递(冒泡和捕获),事件委托,jquery中的事件委托,$event 获取元素,vue事件修饰符
事件传递 ----冒泡和捕获 DOM事件标准定义了两种事件流,这两种事件流分别是捕获和冒泡. 和许多Web技 术一样,在它们成为标准之前,Netscape和微软各自不同地实现了它们.Netscape选 ...
- 【Vue】Vue数据及事件绑定
文章目录 1. 数据绑定 1.1 单向绑定 1.1.1 插值绑定 1.1.2 v-bind绑定 1.2 双向绑定 2. 事件绑定与监听 2.1 方法及内联处理器 2.2 修饰符 事件修饰符 键值修饰符 ...
- vue2[初级]事件处理器
本节内容 什么是事件处理器 例如我们点击一个连接时 只想记录被点击的连接地址 而不是真正的要去跳转到连接 此时需要使用.prevent事件处理器来控制 事件处理器还可以控制当前事件是否需要继续向上渲染 ...
- Vue的数据绑定 事件 键盘 ,以及创建项目改端口号
一.Vue的数据绑定 1.单向数据绑定:将Model绑定到View上,当通过JavaScript代码改变了Model时,View就会自动刷新.不需要进行额外的DOM 操作就可以实现视图和模型的联动 ...
最新文章
- RHCS创建高可用性群集Apache服务器
- 用Flutter改造ZS项目小记一:界面显示一张图片
- 对于随机变量的标准差standard deviation、样本标准差sample standard deviation、标准误差standard error的解释...
- Matplotlib: “Unknown projection '3d'” error
- 实验5 matlab程序设计2,实验5 Matlab程序设计2
- Linux启动tomcat命令行关闭后服务会停止
- 拼多多11.11:无定金、不预售,“好牌子、好实惠”底价直降
- dismiss ios pop效果_iOS实现自定义炫酷的弹出视图(popView)
- redis的hscan命令
- mapguide 安装调试
- 服务器虚拟化厂家排名,鹿死谁手?桌面虚拟化厂商实力大比拼
- python使用 urllib.unquote乱码的原因
- 专科低学历想做web前端开发拿10k、15k高薪,我建议你这样做
- 35岁之前不应该错过的30本书
- 英语四级——常考语法【不断更新中】
- Windows 操作系统
- pinned memory or page locked memory)
- 前端面试:经典面试题Foo与getName()
- 一篇关于视频下载的技术贴(源码)
- 【线代】矩阵的秩和线性方程组的解的情况
热门文章
- 如何修复XML内存“泄漏”
- 灵格斯(lingoes)去广告方法
- SharePoint 2010多语言UI,以及开发人员需要注意的
- swift之Mac中NSView视图里的截图【ScrollView中的内容截图】
- 【codevs3160】 LCS 【后缀自动机】
- 微擎框架小程序 入口
- C# 使用Microsoft.Office.Interop将Excel、Word转换成PDF遇到的问题总结
- UiAutomator控件获取
- 【算法】数组与矩阵问题——找到无序数组中最小的k个数
- MsSql2005如何进行自动定时备份数据库