第四章:计算属性

为了避免过多的逻辑造成模板的臃肿不堪,可使用计算属性来简化逻辑。

1.什么是计算属性

<!DOCTYPE html>

<html lang="en"><head>  
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="example">
<input type="text" v-model="didi"/>
<input type="text" v-model="family"/>
<br/>
didi={{didi}},family={{family}},didiFamily={{didiFamily}} </div> <script src="js/vue.js"></script>
<script>
var vm=new Vue({
el:"#example",
data:{
didi:"didi",
family:"family"
},
computed:{
//一个计算属性的getter
didiFamily:{
get:function(){
//this 指向vm实例
return this.didi+this.family;
}
} }
})
</script> </body>
</html>

当vm.didi和vm.family的值发生变化时,vm.didiFamily的值会自动更新,当然也会同步到DOM元素上。

2.计算属性的性能分析

第五章:表单控件绑定

1.v-model更新表单控件的基本例子

这些基本例子,直接使用value属性,绑定的都是字符串或者checkbox的布尔值。接下来分别介绍。

(1)文本框的使用

当用户操作文本框时,vm.name会自动更新为用户输入的值,同时span也会改变。

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>Title</title></head><body>    <div id="demo">        <span>Welcom,{{name}}!join DDFE</span>        <br/>        <input type="text" v-model="name" placeholder="join DDFE"/>    </div>    <script src="js/vue.js"></script>    <script>        var vm=new Vue({            el:"#demo"        })    </script></body></html>

textInput使用v-model

(2)复选框checkbox的使用

单个复选框的使用和文本框类似,多个复选框,也就是复选框组,被选入的值会放入一个数组。

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>复选框组</title></head><body><div id="demo">    <input type="checkbox" id="flash" value="flash" v-model="bizLines"/>    <label for="flash">        快车    </label>    <br/>    <input type="checkbox" id="premium" value="premium" v-model="bizLines"/>    <label for="premium">        专车    </label>    <br/><input type="checkbox" id="bus" value="bus" v-model="bizLines"/>    <label for="flash">        巴士    </label>    <br/></div><script src="js/vue.js"></script><script>    var vm=new Vue({        el:"#demo",        data:{            bizLines:[]        }    })</script></body></html>

复选框组通过v-model被选中的值会放入数组中

(3)单选按钮radio的使用

当单选按钮被选中时,v-model的变量值会被赋值为对应的value值。

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>单选按钮radio</title></head><body><div id="demo">    <input type="radio" id="flash" value="flash" v-model="bizLines"/>    <label for="flash">        快车    </label>    <br/>    <input type="radio" id="premium" value="premium" v-model="bizLines"/>    <label for="premium">        专车    </label>    <br/>    <input type="radio" id="bus" value="bus" v-model="bizLines"/>    <label for="flash">        巴士    </label>    <br/>    <span>Picked:{{bizLines}}</span></div><script src="js/vue.js"></script><script>    var vm=new Vue({        el:"#demo"    })</script></body></html>

单选按钮使用v-model

(4)select控件使用v-model分为两种情况。

一种是单选select控件,第二种是多选select控件。v-model指令都用于select标签。动态的生成option可以借助v-for指令等。

单选时vm.selected为对应的option的value值。多选会被放入一个数组中,多选是selectr有multiple属性,浏览器窗口想要多选可以借助ctrl和shift快捷键。

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>下拉菜单的选择</title></head><body><div id="demo">    <select v-model="bizLine">        <option selected value="flash">快车</option>        <option value="premium">专车</option>        <option value="bus">巴士</option>    </select>    <span>selected:{{bizLine}}</span>    <br/>    <select v-model="bizLine2" multiple>        <option selected value="flash">快车</option>        <option value="premium">专车</option>        <option value="bus">巴士</option>    </select>    <span>selected:{{bizLine2|json}}</span></div><script src="js/vue.js"></script><script>    var vm=new Vue({        el:"#demo"    })</script></body></html>

2.动态的值绑定

通过v-bind代替直接使用value属性,那么除了字符串,还可以是数值、对象、数组等非字符串的值。

(1)checkbox

3.v-model指令的修饰词及其源码分析

(1)lazy

默认情况下,v-model在input事件中同步输入框的值与数据,而添加了lazy特性后,在change事件中去掉同步性。

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>Title</title></head><body><!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>Title</title></head><body><div id="demo">    <span>Welcom,{{name}}!join DDFE</span>    <br/>    <input type="text" v-model="name" placeholder="join DDFE" /></div><script src="js/vue.js"></script><script>    var vm=new Vue({        el:"#demo"    })</script></body></html></body></html>

lazy修饰词

同样是之前的代码,只是添加了lazy属性,那么name变量就不会同步了。

<!--源码目录:src/directives/public/model/text.js-->

var lazy = this.params.lazy  //获取到参数的lazy的布尔值//...if (!isRange && !lazy) {     //如果element的type值不是range,而且lazy为false      this.on('focus', function () {        self.focused = true      })      this.on('blur', function () {        self.focused = false        // do not sync value after fragment removal (#2017)        if (!self._frag || self._frag.inserted) {          self.rawListener()        }      })    }//...if (this.hasjQuery) {      const method = jQuery.fn.on ? 'on' : 'bind'      jQuery(el)[method]('change', this.rawListener)      if (!lazy) {        jQuery(el)[method]('input', this.listener)      }    } else {      this.on('change', this.rawListener)      if (!lazy) {        this.on('input', this.listener)      }    }

(2)debounce

<!--源码目录:src/directives/public/model/text.js-->

if (debounce) {      this.listener = _debounce(this.listener, debounce)    }
// Support jQuery events, since jQuery.trigger() doesn't // trigger native events in some cases and some plugins // rely on $.trigger() // // We want to make sure if a listener is attached using // jQuery, it is also removed with jQuery, that's why // we do the check for each directive instance and // store that check result on itself. This also allows // easier test coverage control by unsetting the global // jQuery variable in tests. this.hasjQuery = typeof jQuery === 'function' if (this.hasjQuery) { const method = jQuery.fn.on ? 'on' : 'bind' jQuery(el)[method]('change', this.rawListener) if (!lazy) { jQuery(el)[method]('input', this.listener) } } else { this.on('change', this.rawListener) if (!lazy) { this.on('input', this.listener) } }

(3)number

<!--源码目录:src/directives/public/model/text.js-->

var number = this.params.number//****this.listener = this.rawListener = function () {      if (composing || !self._bound) {        return      }      var val = number || isRange        ? toNumber(el.value)        : el.value      self.set(val)      // force update on next tick to avoid lock & same value      // also only update when user is not typing      nextTick(function () {        if (self._bound && !self.focused) {          self.update(self._watcher.value)        }      })    }//****

<!--源码目录:src/util/lang.js-->

export function toNumber (value) {  if (typeof value !== 'string') {    return value  } else {    var parsed = Number(value)    return isNaN(parsed)      ? value      : parsed  }}

vue.js基础知识篇(3):计算属性、表单控件绑定的更多相关文章

  1. vue.js基础知识篇(4):过滤器、class与style的绑定2

    代码下载:网盘 欢迎私信 第一章:过滤器 过滤器是对数据进行处理并返回结果的函数. 1.语法 语法是使用管道符"|"进行连接.过滤器可以接收参数,跟在过滤器后面,带引号的参数被当做 ...

  2. Vue.js-----轻量高效的MVVM框架(七、表单控件绑定)

    话不多说,先上完整代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> ...

  3. vue.js基础知识篇(1):简介、数据绑定

    目录第一章:vue.js是什么? 第二章:数据绑定第三章:指令第四章:计算属性第五章:表单控件绑定代码链接: http://pan.baidu.com/s/1qXCfzRI 密码: 5j79 第一章: ...

  4. Vue表单控件绑定

    前面的话 本文将详细介绍Vue表单控件绑定 基础用法 可以用 v-model 指令在表单控件元素上创建双向数据绑定.它会根据控件类型自动选取正确的方法来更新元素.v-model本质上不过是语法糖,它负 ...

  5. js进阶 9-6 js如何通过name访问指定指定表单控件

    js进阶 9-6 js如何通过name访问指定指定表单控件 一.总结 一句话总结:form中控件的三种访问方式:2formElement 1document 1.form中控件的三种访问方式? 1.f ...

  6. vue.js基础知识篇(7):表单校验详解

    目录 网盘 第12章:表单校验 1.npm安装vue-validator $ npm install vue-validator 代码示例: var Vue=require("vue&quo ...

  7. vue.js基础知识篇(2):指令详解

    第三章:指令 1.语法 指令以v-打头,它的值限定为绑定表达式,它负责的是按照表达式的值应用某些行为到DOM上. 内部指令有v-show,v-else,v-model,v-repeat,v-for,v ...

  8. Vue.js学习笔记 第七篇 表单控件绑定

    本篇主要说明表单控件的数据绑定,这次没有新的知识点 文本框 1.普通文本框 <div id="app-1"> <p><input v-model=&q ...

  9. Vue.js学习 Item9 – 表单控件绑定

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

随机推荐

  1. 学习笔记TF030:实现AlexNet

    ILSVRC(ImageNet Large Scale Visual Recognition Challenge)分类比赛.AlexNet 2012年冠军(top-5错误率16.4%,额外数据15.3 ...

  2. Java 9 揭秘(15. 增强的弃用注解)

    Tips 做一个终身学习的人. 主要介绍以下内容: 如何弃用API @deprecate Javadoc标签和@Deprecation注解在弃用的API中的角色 用于生成弃用警告的详细规则 在JDK ...

  3. 回味Python2.7——笔记2

    一.模块 模块是包括 Python 定义和声明的文件.文件名就是模块名加上 .py 后缀.模块的模块名(做为一个字符串)可以由全局变量 __name__ 得到. 1. 模块可以导入其他的模块. 一个( ...

  4. django 表单提交 post 、get

    介绍 : django项目开发必须懂的知识点,下面使用的数据库是mysql , models.py  数据库表结构, # -*- coding: utf-8 -*-from __future__ im ...

  5. (转)Synchronized(对象锁)和Static Synchronized(类锁)的区别

    场景:面试的时候经常用得到! 1 综述 Synchronized和Static Synchronized区别 一个是实例锁(锁在某一个实例对象上,如果该类是单例,那么该锁也具有全局锁的概念),一个是全 ...

  6. Swift 细节

    1.swift ?和 !的区别 1.1 Swift语言使用var定义变量,但和别的语言不同,Swift里不会自动给变量赋初始值,也就是说变量不会有默认值,所以要求使用变量之前必须要对其初始化.如果在使 ...

  7. python 中 list 的各项操作

    最近在学习 python 语言.大致学习了 python 的基础语法.觉得 python 在数据处理中的地位和它的 list 操作密不可分. 特学习了相关的基础操作并在这里做下笔记. ''' Pyth ...

  8. 3.commonjs模块

    1.首先建一个math.js exports.add = function(a, b){ return a + b; } exports.sub = function(a, b){ return a ...

  9. Hbase架构与原理

    Hbase架构与原理 HBase是一个分布式的.面向列的开源数据库,该技术来源于 Fay Chang所撰写的Google论文"Bigtable:一个结构化数据的分布式存储系统".就 ...

  10. yhTriangle_LinkQueue(队列实现杨辉三角)

    #include"LinkQueue.h" void yhTriangle(int n) { LinkQueue<int> A; int s,t; A.Inqueue( ...