我们还是先回顾一下上一次的重点:

1.事件绑定,我们可以对分别用方法和js表达式对事件进行处理

2.当方法名带括号的时候,在方法中一定要传参;而不带括号的时候,vm会自动配置默认event

3.各类事件修饰器

之前我们提到过表单绑定,那么现在我们来深入了解一下,Vue这一令人惊奇的双向表单绑定功能:
直接进入正题:
 
<input v-model=" message ">
<p>{{ message }}</p>
这是最简单的表单双向绑定,标签P中的值将随着vm中值的变化而变化
值得注意的是,就算我们这样写:
<input v-model=" message " value=" ye ">
也不会读取value,message的值只会随着vm中的数据而变化,也就应证了vue数据驱动视图的原理
 
我们再延展一下:
<span> 文本框中输入的值为: </span>
<p> {{ message }} </p>
<textarea v-model=" message " ></textarea>
同理:
我们这样写也是没有作用的:
<textarea>{{ message }}</textarea>
 
继续深入:
当我们在使用多选框的时候:
 
单个checkbox:
<input v-model="checked" type="checkbox" id=" lla ">
<lable for=" lla ">{{ checked }}</lable>
这个时候checked的值将会在true和false之间切换。
 
多个checkbox的时候:
<input type=" checkbox " id="a" value="f" v-model="checked">
<lable for="a">a</lable>
 
<input type=" checkbox " id="b" value="m" v-model="checked">
<lable for="b">b</lable>

<input type=" checkbox " id="c" value="c" v-model="checked">
<lable for="c">c</lable>
 
<span>选中的为:{{ checked }}</span>

当我们对input设置了value的时候,那么checked的值就不再是true or false了,而是相应的value值

 
new Vue:({
    el:'',
    data:{
        checked:[]
}
})
如上面的代码,这个时候,返回在span中的值,是以数组的形式渲染的

单个radio:
<input type="radio" id="a" value="f" v-model="picked">
<lable for=" a ">a</lable> 
 
<input type="radio" id="b" value="m" v-model="picked">
<lable for=" b ">b</lable>
 
<span>{{ picked }}</span>

其实和多选框的原理是一样的,区别仅仅在于这里span中的值不是一个数组而是一个单一的值

 
下拉菜单 select:::
 
单选:
 
<select v-mode="selected">
    <option>a</option>
    <option>b</option>
    <option>c</option>
</select>
 
<span>{{ selected }}</span>
option标签没有指定value属性时,那么返回的值就是标签中的内容
 
 
多选:
<select v-mode="selected" multiple>
    <option>a</option>
    <option>b</option>
    <option>c</option>
</select>
 
<span>{{ selected }}</span>

这和多选框checked一样,返回的值依然为一个数组

 
 
渲染option列表:
 
我们可以发现option总是为多个,那么我们为何不能用列表来渲染呢:
<select v-model="selected">
    <option v-for=" item in items " v-bind:value=" option.value ">{{ option.text }}</option>
</select>
 
<span>{{ selected }}</span> 
 
new Vue({
    el:'',
    data:{
        selected:'a',
        option:
            [
{ text: 'One', value: 'A' },
{ text: 'Two', value: 'B' },
{ text: 'Three', value: 'C' }
]
 
}
})
这里需要注意的是:
我们在这里绑定了option的value属性,如果不对它进行绑定,那么最后选出来的值就是
value而不是text
 
 
 
下面我们来总结一下数据绑定及了解一下相关修饰器:
<input type="radio" v-model="picked" value="a">
//选中picked时是字符串 ”a“
<input type="radio" v-model="toggle">
//选中时,将会是true和false间切换
<select v-model="selected">
    <option value="aaa">aaa</option>
</select> 
//selected时会输入字符串aaa
 
 
<input type="checkbox" v-model="toggle"  v-bind:true-value="a" v-bind:false-value="b">
//  vm.toggle === vm.a (checked)
// vm.toggle === vm.b( unchecked )
 
这里其实没有多大变化,我们仅仅是对true和false分别绑定了一个值而已,很好理解
 
<select v-model="selected">
    <option v-bind:value=" { number : aaa } ">aaa</option>
</select>
 
vm.selected.number === aaa

这里我们绑定了一个对象,相应的我们也读取了对象的值
 
 
接下来进入今天最后的环节,讲一讲数据绑定中相应的修饰器:
 
Lazy:
<input v-model.lazy="message">
// 这样的话,视图将会在输入完成之后变化,而不会即时变化
 
number:
<input v-model.number="message">
//这个可以强制将输入的数据转换成数字
 
trim
<input v-model.trim="message">
//自动去除字符串收尾的空格。
 
今天以此收尾,昨天晚上因为其他事耽搁了,后面尽量补上一篇,同时明天晚上也许也会交白卷,希望大家谅解,这两天学习状态不是很好,会及时调整,感谢各位的支持,晚安。

Vue学习之路---No.6(分享心得,欢迎批评指正)的更多相关文章

  1. vue学习之路 - 4.基本操作(下)

    vue学习之路 - 4.基本操作(下) 简述:本章节主要介绍 vue 的一些其他常用指令. Vue 指令 这里将 vue 的指令分为系统内部指令(vue 自带指令)和用户自定义指令两种. 系统内部指令 ...

  2. Vue学习之路之登录注册实例代码

    Vue学习之路之登录注册实例代码:https://www.jb51.net/article/118003.htm vue项目中路由验证和相应拦截的使用:https://blog.csdn.net/wa ...

  3. Vue学习之路---No.4(分享心得,欢迎批评指正)

    这里说声抱歉,周末因为有其他事,没有更新博客,那么我们今天继续上周5的说. 老规矩,先回顾一下上一次的重点: 1.利用V-if和v-else来提到show()和hide(),同时要记住,v-else一 ...

  4. JAVA学习之路与大家分享

    这是我四年以前总结的JAVA学习之路,希望对初学者或想从事JAVA开发的人有帮助. 本人是软件工程专业出身,先后学过C.C++.JAVA.VB.delphi等等开发语言以及网络相关管理技术.哎,好久不 ...

  5. Vue学习之路第一篇(学习准备)

    1.开发工具的选择 这个和个人的开发习惯有关,并不做强求,厉害的话用记事本也可以.但是我还是建议用人气比较高的编辑工具,毕竟功能比较全面,开发起来效率比较高. 我之前写前端一直用的是sublimete ...

  6. Vue学习之路---No.2(分享心得,欢迎批评指正)

    昨天我们大致了解了有关Vue的基础知识和语法:今天我们继续在大V这条路上前进. 首先,我们回忆一下昨天提到的相关知识点: 1.了解Vue的核心理念------"数据驱动视图" 2. ...

  7. Vue学习之路---No.7(分享心得,欢迎批评指正)

    老规矩,先回顾一下上回的重点: 1.对于input框,若为单选框,如果没有对其设置value,那么其checked的值将在true Or false之间切换:如果设置了value,那么将会切换valu ...

  8. Vue学习之路---No.3(分享心得,欢迎批评指正)

    同样的,我们先来回顾一下昨天学习的内容: 1.利用v-once来组织双向绑定 2.filter{}过滤器的使用(详情请看上一章) 3.computed(计算属性),利用computed属性实现filt ...

  9. Vue学习之路---No.1(分享心得,欢迎批评指正)

    首先为了打消大家对Vue.js存在的顾虑,先通过大家所熟知的JQ作为对比. 都知道JQ的语法相对简单.清楚.使用方便.功能齐全: 那么Vue.js呢,同样的,Vue.js与JQ在很多地方都是相同之处, ...

随机推荐

  1. Spring内部bean无法通过id获取

    内部Bean注入正常,但是直接在context中getBean是得不到的: <?xml version="1.0" encoding="UTF-8"?&g ...

  2. 马丁 福勒 Martin Fowler 关于依赖注入和反转控制的区别

    马丁 福勒 Martin Fowler 关于依赖注入和反转控制的区别 http://martinfowler.com/articles/injection.html 中文翻译:http://files ...

  3. Spring IO Platform简介及示例

    什么是Spring IO Platform Spring IO Platform,简单的可以认为是一个依赖维护平台,该平台将相关依赖汇聚到一起,针对每个依赖,都提供了一个版本号: 这些版本对应的依赖都 ...

  4. ubuntu下php编译

    1.安装依赖 sudo apt-get install libjpeg-devsudo apt-get install libxml2-devsudo apt-get -y install libjp ...

  5. 微信小程序----关于变量对象data 和 前端wxml取后台js变量值

    (一)页面变量对象data 对象data 有两个方面用途 第一,前端wxml的数据渲染是通过设置此对象中定义的变量进行关联展现的 第二,定义JS页面中的页面局部变量,使其整个页面中可使用或调用 对象d ...

  6. 未来手机Alo即将问世!全息投影手机的新高峰!全息3d 网

    文章来源:网络         编辑:大熊 [摘要]全息投影手机很早就开始炒,网络上的概念机也是丛出不穷,那么这款出自法国的概念机又是多么的奇葩?全息 3d 网带你一探究竟. 据外媒报道,在不久将来语 ...

  7. linux文件相关的命令

    1.linux下的文件分为字符设备文件和块设备文件 2.文件的属性有读写权限.执行权限.访问时间.修改时间.状态改变时间等. 状态改变时间指修改了文件的读写权限或者所有者等操作. 3.ls -l 执行 ...

  8. 谨慎能捕千秋蝉(二)——CSRF

    CSRF(Cross Site Request Forgery)跨站点请求伪造. CSRF的本质是当重要操作的参数都能被攻击者预测到,才能成功伪造请求. 一.场景演示 下图是一个伪造请求的场景,按顺序 ...

  9. Ajax跨域实现淘宝/百度搜索下拉提示效果

    最近学到Ajax,觉得自己对与前后端的数据交互有了一个基本的了解.下面是Ajax应用到淘宝/百度的搜索功能的一个简单的小实例,就是输入一个词,下拉框中自动显示匹配的内容:

  10. linux下基于rsync + find命令实现文件同步机制

    rsync和find是linux系统自带的命令,如果没有安装可以找到系统安装盘或者ISO文件,里面有rpm包,安装一下就可以了.       具体思路如下:             1)可以实现定时进 ...