你可以使用 v-on 指令来绑定并监听 DOM 事件。绑定的内容可以是一个当前实例上的方法 (后面无需跟括号) 或一个内联表达式。如果提供的是一个方法,则原生的 DOM event 会被作为第一个参数传入,同时这个 event 会带有 targetVM 属性,指向触发该事件的相应的 ViewModel:

触发一个方法函数

触发一个表达式

new Vue({

el: '#demo',

data: {

n: 0

},

methods: {

onClick: function (e) {

console.log(e.targetVM.n);

console.log(e.target.tagName);// "A"

console.log(e.targetVM === this);// true

}

}

});

执行表达式

当在 v-repeat 里使用 v-on 时,targetVM 显得很有用,因为 v-repeat 会创建大量子 ViewModel。但是,通过执行表达式的方式,把代表当前 ViewModel 数据对象的别名传进去,会更方便直观一些:

  • {{item.text}}

Submit

new Vue({

el: '#list',

data: {

items: [

{ text: 'one', done: true },

{ text: 'two', done: false }

]

},

methods: {

toggle: function (item) {

console.info(item.done);

item.done = !item.done;

console.info(item.done);

},

submit: function (msg, e) {

e.stopPropagation();

console.info(msg + ' submit is called!');

}

}

})

当你想要在表达式中访问原来的 DOM event,你可以传递一个 $event 参数进去。

key过滤器

当监听键盘事件时,我们常常需要判断常用的 key code。Vue.js 提供了一个特殊的只能用在 v-on 指令的过滤器:key。它接收一个表示 key code 的参数并完成判断:

系统有很多预设值可以使用,例如:

预设值为:enter tab delete esc up down left right space

为什么在HTML中使用监听器

你可能会注意到整个事件监听的方式违背了 “separation of concern” 的传统理念。不必担心,因为所有的 Vue.js 事件处理方法和表达式都严格绑定在当前视图的 ViewModel 上,它不会导致任何维护困难。实际上,使用 v-on 还有更多好处:

它便于在 HTML 模板中轻松定位 JS 代码里的对应方法实现。

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

当一个 ViewModel 被销毁时,所有的事件监听都会被自动移除。你无须担心如何自行清理它们。

html中事件监听的使用,Vue.JS入门篇--事件监听相关推荐

  1. js模板字符串自定义类名_【Vue.js 入门到实战教程】07Vue 组件注册 | 基本使用和组件嵌套...

    来源 | https://xueyuanjun.com/post/21929除了前面介绍的基本语法之外,Vue.js 还支持通过组件构建复杂的功能模块,组件可以称得上是 Vue.js 的灵魂,是 Vu ...

  2. vue设置cookie的domain无效_【Vue.js入门到实战教程】16Tailwind 与 Bootstrap 的区别和使用入门...

    来源 | https://xueyuanjun.com/post/22065我们知道,从 Laravel 8 开始,自带前端脚手架代码默认兼容 Tailwind CSS 框架,取代了之前的 Boots ...

  3. Vue.js入门教程-组件注册

    一.组件创建 1.1 创建步骤 创建Vue的组件都有三个基本步骤是 [①创建组件构造器.②注册组件和③使用组件]. 1.2 基本示例 比如,我们创建一个Button组件. // 1. 创建一个组件构造 ...

  4. Vue.js入门指南(一)

      前  言 JRedu 之前用过一段时间的AnglarJS 1.X,在低版本的AngularJS中,脏值检查在变量增多的情况下会影响程序的响应速度.后期的2.X和更高版本在脏值检查等问题上做了优化, ...

  5. Vue.js入门教程(适合初学者)

    Vue.js入门教程 Vue官网网址:Vue.js 中文网 Vue.js Vue.js是渐进式JavaScript 框架,是一套构建用户界面的渐进式框架.也可以说Vue.js 是一个用来构建网页界面的 ...

  6. vue.js绑定单击事件和双击事件(共用同一个方法代码示例)

    首先,先来学习一下绑定单击事件和双击事件的2个常用标签: v-on:click  表示单击 v-on:dblclick  表示双击 示例代码如下: <!DOCTYPE html> < ...

  7. 【一文学会】vue.js入门到放弃

    最近正好学习了vue.js就准备将此记录下来,希望能给各位做个参考,当然因为技术有限所以出现很多错误,烦请大佬们能够不吝赐教,此篇博客会一直保持更新,以后关于vue就在本篇博文上填加内容了. VueJ ...

  8. Vue.js 入门 :去哪儿网APP案例 学习记录

    推荐博客 Vue 2.5 开发 去哪儿 旅游网站项目记录 项目源码 : https://gitee.com/doublesgzl/Travel 第六章 项目实战 6-1 环境配置 (建议看下视频) 6 ...

  9. [Vue.js] 一篇超级长的笔记,给《Vue.js 实战》划个重点

    本文前言 本笔记建立在书籍<Vue.js实战 / 梁灏编著>的基础上,旨在帮助有 Vue.js 基础的朋友快速回忆 Vue.js 的细碎内容.初学者建议阅读<Vue.js实战> ...

最新文章

  1. 从命令行列出所有环境变量?
  2. 《Python数据科学指南》——1.23 采用键排序
  3. oracle查询中over(partition by ...order by ...)用法
  4. 百度在线解析站不限速下载
  5. 服务器双cpu性能强不,双CPU的电脑用起来,性能和功耗都是原来的两倍?
  6. 最新试客联盟JS逆向分析
  7. HTTP之Web服务器
  8. 独家揭秘,106岁的IBM靠什么完成了世纪大转型|钛度专访
  9. quick-cocos2d-x GameCenter 排行榜
  10. python模拟浏览器访问百度_selenium与python自动化测试模拟登录百度
  11. 欧创芯原装OC 5209芯片降压型 LED 恒流驱动器,SOT89-5 封装
  12. Failed to obtain JDBC Connection; nested exception is java.sql.SQLException: Access denied for user
  13. python正则表达式提取电话号码_用于提取电话号码的正则表达式
  14. 硬件模块应用之超声波测距模块SRF05应用
  15. 一声不吭辞职的人都是聪明人
  16. 高德地图——地图渲染及关键字搜索POI功能vue2/web端
  17. 毕业论文排版及格式修改“骚操作”和常见误区(Word基础)
  18. mysql基于Java web的电动车销售平台毕业设计源码201524
  19. 金融分析:图形可视化plotly绘图思路—多子图教程
  20. Matplotlib中的plt和ax都是啥?

热门文章

  1. [重要]招募计划 - 积微速成报名结果
  2. 多路脉冲发生器设计(脉冲个数,脉冲宽度可控)
  3. 用Python掌握QQ群聊天记录数据分析
  4. Android中APK打包流程
  5. ios12升级, App应用崩溃闪退
  6. python 信号.同步 day07
  7. 安卓手机小说阅读器_百万小说阅读器app免费版下载-百万小说阅读器app手机版下载v1.4...
  8. 数据加密与安全专题《mbedtls工具篇,实用教程1@mbedtls简介和安装教程》
  9. 编写一个用于字符串比较的函数
  10. redis多实例常见部署方法和使用