方法与事件处理器

方法处理器

可以用 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 有几个好处:

  1. 扫一眼 HTML 模板便能轻松定位在 JavaScript 代码里对应的方法。

  2. 因为你无须在 JavaScript 里手动绑定事件,你的 ViewModel 代码可以是非常纯粹的逻辑,和 DOM 完全解耦,更易于测试。

  3. 当一个 ViewModel 被销毁时,所有的事件处理器都会自动被删除。你无须担心如何自己清理它们。

转载于:https://www.cnblogs.com/jiangxiaobo/p/5425000.html

Vue 方法与事件处理器相关推荐

  1. Vue基础之事件处理器

    监听事件: 可以用 v-on 指令监听 DOM 事件来触发一些 JavaScript 代码 示例 方法事件处理器: 许多事件处理的逻辑都很复杂,所以直接把 JavaScript 代码写在 v-on 指 ...

  2. vue样式绑定与事件处理器的基本使用

    目录 Vue.js 样式绑定 Vue.js 事件处理器 事件修饰符 Vue.js 样式绑定

  3. 08.vue.js实战笔记(计算属性、v-bind及class和style的绑定、内置指令、方法与事件)

    1.计算属性 所有的计算属性都以函数的形式写在vue实例的computed选项内,最终返回计算后的结果 <!DOCTYPE html> <html lang="en&quo ...

  4. Vue模块语法下(事件处理器自定义组件组件通信)

                                                                    文章目录 一.事件处理器 事件修饰符 二.自定义组件 组件简介 全局和局 ...

  5. 前端MVC Vue2学习总结(四)——条件渲染、列表渲染、事件处理器

    一.条件渲染 1.1.v-if 在字符串模板中,如 Handlebars ,我们得像这样写一个条件块: <!-- Handlebars 模板 --> {{#if ok}}<h1> ...

  6. vue学习:事件传递(冒泡和捕获),事件委托,jquery中的事件委托,$event 获取元素,vue事件修饰符

    事件传递 ----冒泡和捕获 DOM事件标准定义了两种事件流,这两种事件流分别是捕获和冒泡. 和许多Web技 术一样,在它们成为标准之前,Netscape和微软各自不同地实现了它们.Netscape选 ...

  7. 【Vue】Vue数据及事件绑定

    文章目录 1. 数据绑定 1.1 单向绑定 1.1.1 插值绑定 1.1.2 v-bind绑定 1.2 双向绑定 2. 事件绑定与监听 2.1 方法及内联处理器 2.2 修饰符 事件修饰符 键值修饰符 ...

  8. vue2[初级]事件处理器

    本节内容 什么是事件处理器 例如我们点击一个连接时 只想记录被点击的连接地址 而不是真正的要去跳转到连接 此时需要使用.prevent事件处理器来控制 事件处理器还可以控制当前事件是否需要继续向上渲染 ...

  9. Vue的数据绑定 事件 键盘 ,以及创建项目改端口号

    一.Vue的数据绑定 1.单向数据绑定:将Model绑定到View上,当通过JavaScript代码改变了Model时,View就会自动刷新.不需要进行额外的DOM 操作就可以实现视图和模型的联动 ​ ...

最新文章

  1. RHCS创建高可用性群集Apache服务器
  2. 用Flutter改造ZS项目小记一:界面显示一张图片
  3. 对于随机变量的标准差standard deviation、样本标准差sample standard deviation、标准误差standard error的解释...
  4. Matplotlib: “Unknown projection '3d'” error
  5. 实验5 matlab程序设计2,实验5 Matlab程序设计2
  6. Linux启动tomcat命令行关闭后服务会停止
  7. 拼多多11.11:无定金、不预售,“好牌子、好实惠”底价直降
  8. dismiss ios pop效果_iOS实现自定义炫酷的弹出视图(popView)
  9. redis的hscan命令
  10. mapguide 安装调试
  11. 服务器虚拟化厂家排名,鹿死谁手?桌面虚拟化厂商实力大比拼
  12. python使用 urllib.unquote乱码的原因
  13. 专科低学历想做web前端开发拿10k、15k高薪,我建议你这样做
  14. 35岁之前不应该错过的30本书
  15. 英语四级——常考语法【不断更新中】
  16. Windows 操作系统
  17. pinned memory or page locked memory)
  18. 前端面试:经典面试题Foo与getName()
  19. 一篇关于视频下载的技术贴(源码)
  20. 【线代】矩阵的秩和线性方程组的解的情况

热门文章

  1. 如何修复XML内存“泄漏”
  2. 灵格斯(lingoes)去广告方法
  3. SharePoint 2010多语言UI,以及开发人员需要注意的
  4. swift之Mac中NSView视图里的截图【ScrollView中的内容截图】
  5. 【codevs3160】 LCS 【后缀自动机】
  6. 微擎框架小程序 入口
  7. C# 使用Microsoft.Office.Interop将Excel、Word转换成PDF遇到的问题总结
  8. UiAutomator控件获取
  9. 【算法】数组与矩阵问题——找到无序数组中最小的k个数
  10. MsSql2005如何进行自动定时备份数据库