• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >vue > Vue.JS入门教程之事件监听

Vue.JS入门教程之事件监听

作者:hutou 字体:[增加 减小] 来源:互联网 时间:2017-05-30

本文主要包含vue.js入门,vue.js入门视频教程,vue.js入门教程,vue.js从入门到放弃,vue.js快速入门等相关知识,hutou 希望在学习及工作中可以帮助到您

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

<div id="demo">
 <a v-on="click: onClick">触发一个方法函数</a>
 <a v-on="click: n++">触发一个表达式</a>
</div>
</div>
 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
  }
 }
 });
</div>

执行表达式

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

<ul id="list">
 <li v-repeat="item in items" v-on="click: toggle(item)">
 {{item.text}}
 </li>
 <button v-on="click: submit('hello!', $event)">Submit</button>
</ul>
</div>
 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!');
  }
 }
 })
</div>

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

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

 <!-- 只有当 keyCode 等于 13 时才调用方法 -->
 <input v-on="keyup:mySubmit | key 13">
</div>

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

<!-- 效果同上 -->
<input v-on="keyup:submit | key 'enter'">
</div>

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

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

它便于在 HTML 模板中轻松定位 JS 代码里的对应方法实现。
因为你无须在 JS 里手动绑定事件,你的 ViewModel 代码可以是非常纯粹的逻辑,和 DOM 完全解耦。这会更易于测试。
当一个 ViewModel 被销毁时,所有的事件监听都会被自动移除。你无须担心如何自行清理它们。

本文已被整理到了《Vue.js前端组件学习教程》,欢迎大家学习阅读。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

</div>

您可能想查找下面的文章:

  • Vue.js——60分钟快速入门
  • Vue.js 60分钟快速入门教程
  • 快速入门Vue
  • Vue.JS入门教程之自定义指令
  • Vue.JS入门教程之事件监听
  • Vue.JS入门教程之列表渲染
  • Vue.JS入门教程之处理表单
  • vue.js初学入门教程(2)
  • vue.js初学入门教程(1)
  • Vue.js快速入门教程

相关文章

  • 2017-05-30Vue.js第四天学习笔记(组件)
  • 2017-05-30vue开发心得和技巧分享
  • 2017-05-30Vue实现动态响应数据变化
  • 2017-05-30require.js 加载 vue组件 r.js 合并压缩的实例
  • 2017-05-30Vue概念及常见命令介绍(1)
  • 2017-05-30Vue.js第一天学习笔记(数据的双向绑定、常用指令)
  • 2017-05-30vue.js初学入门教程(1)
  • 2017-05-30Vue.js组件tree实现省市多级联动
  • 2017-05-30Vue.js第三天学习笔记(计算属性computed)
  • 2017-05-30vue.js将unix时间戳转换为自定义时间格式

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • vue-hook-form使用详解
    • 使用vue.js写一个tab选项卡效果
    • vue2滚动条加载更多数据实现代码
    • vue2.0实现倒计时的插件(时间戳 刷新 跳转 都不影响)
    • Vuejs第九篇之组件作用域及props数据传递实例详解
    • Vue.js双向绑定实现原理详解
    • 详解vue-router 2.0 常用基础知识点之router.push()
    • 利用Vue.js框架实现火车票查询系统(附源码)
    • vue.js 左侧二级菜单显示与隐藏切换的实例代码
    • Vue.js实战之利用vue-router实现跳转页面

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有