博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Vue.js入门学习(五)方法与事件处理器、表单控件绑定
阅读量:2390 次
发布时间:2019-05-10

本文共 1908 字,大约阅读时间需要 6 分钟。

方法与事件处理器

方法处理器

可以用 v-on(简写@) 指令监听 

我们绑定了一个单击事件处理器到一个方法 
greet
var vm = new Vue({  el: '#example',  data: {    name: 'Vue.js'  },  // 在 `methods` 对象中定义方法  methods: {    greet: function (event) {      // 方法内 `this` 指向 vm      alert('Hello ' + this.name + '!')      // `event` 是原生 DOM 事件      alert(event.target.tagName)    }  }})// 也可以在 JavaScript 代码中调用方法vm.greet() // -> 'Hello Vue.js!'

内联语句处理器

除了直接绑定到一个方法,也可以用内联 JavaScript 语句:

类似于内联表达式,事件处理器限制为一个语句

有时也需要在内联语句处理器中访问原生 DOM 事件。可以用特殊变量 $event 把它传入方法:

事件修饰符

在事件处理器中经常需要调用 event.preventDefault() 或 event.stopPropagation()。尽管我们在方法内可以轻松做到,不过让方法是纯粹的数据逻辑而不处理 DOM 事件细节会更好。

为了解决这个问题,Vue.js 为 v-on 提供两个 事件修饰符.prevent 与 .stop

...
...

按键修饰符

在监听键盘事件时,我们经常需要检测 keyCode。Vue.js 允许为 v-on 添加按键修饰符:

 

全部的按键别名:

  • enter
  • tab
  • delete
  • esc
  • space
  • up
  • down
  • left
  • right

为什么在 HTML 中监听事件?

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

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

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

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

表单控件绑定

本节介绍 Vue.js 表单控件绑定,主要了解 v-model 指令的使用。

基础用法

可以用 v-model 指令在表单控件元素上创建双向数据绑定。根据控件类型它自动选取正确的方法更新元素。尽管有点神奇,v-model 不过是语法糖,在用户输入事件中更新数据,以及特别处理一些极端例子。

Text    CheckBox(单个勾选框、逻辑值/多个勾选框、绑定到同一数组)    Radio   Select(单选/多选、绑定到一个数组)
动态选项,用v-for渲染

值绑定

对于单选按钮,勾选框及选择框选项,v-model 绑定的值通常是静态字符串(对于勾选框是逻辑值):

但是有时我们想绑定值到 Vue 实例一个动态属性上。可以用 
v-bind
 做到。 而且 
v-bind
 允许绑定输入框的值到非字符串值。

参数特性

lazy

在默认情况下,v-model 在input 事件中同步输入框值与数据,可以添加一个特性 lazy,从而改到在 change 事件中同步:

number

如果想自动将用户的输入保持为数字,可以添加一个特性 number

debounce

debounce 设置一个最小的延时,在每次敲击之后延时同步输入框的值与数据。如果每次更新都要进行高耗操作(例如在输入提示中 Ajax 请求),它较为有用。

注意 
debounce
 参数不会延迟 input 事件:它延迟“写入”底层数据。因此在使用 
debounce
 时应当用 
vm.$watch()
 响应数据的变化。若想延迟 DOM 事件,应当使用
debounce 过滤器。

转载地址:http://udlab.baihongyu.com/

你可能感兴趣的文章
使用 Apache MINA 开发高性能网络应用程序
查看>>
五分钟学会使用spring-data-cassandra快速实现数据的访问
查看>>
Build self-healing distributed systems with Spring Cloud
查看>>
如何利用Spring Cloud构建起自我修复型分布式系统
查看>>
Java代码实现设置系统时间
查看>>
java -D参数简化加入多个jar
查看>>
用Erlang开发的文档数据库系统CouchDB
查看>>
Apache Commons工具集简介
查看>>
Apache Cayenne—辣椒你吃了吗?
查看>>
云应用开发工具:Spring Cloud 1.0 正式发布
查看>>
[转]在VC中使用智能指针操作Excel
查看>>
关于Linux命令行环境下无线网卡的配置
查看>>
C++的朋友,你都在用什么连数据库啊
查看>>
Setup Kubernetes on a Raspberry Pi Cluster easily the official way!
查看>>
Installing Kubernetes on Linux with kubeadm
查看>>
k8s-Building Large Clusters
查看>>
[转]stl 通用排序算法解析
查看>>
分布式存储系统GlusterFS初体验
查看>>
GlusterFS常用命令小结
查看>>
GlusterFS分布式文件系统使用简介
查看>>