Vue.js是当下很火的一个JavaScript MVVM库,它是以数据驱动和组件化的思想构建的。相比于Angular.js,Vue.js提供了更加简洁、更易于理解的API,使得我们能够快速地上手并使用Vue.js。

如果你之前已经习惯了用jQuery操作DOM,学习Vue.js时请先抛开手动操作DOM的思维,因为Vue.js是数据驱动的,你无需手动操作DOM。它通过一些特殊的HTML语法,将DOM和数据绑定起来。一旦你创建了绑定,DOM将和数据保持同步,每当变更了数据,DOM也会相应地更新。

当然了,在使用Vue.js时,你也可以结合其他库一起使用,比如jQuery。

MVVM模式

下图不仅概括了MVVM模式(Model-View-ViewModel),还描述了在Vue.js中ViewModel是如何和View以及Model进行交互的。

ViewModel是Vue.js的核心,它是一个Vue实例。Vue实例是作用于某一个HTML元素上的,这个元素可以是HTML的body元素,也可以是指定了id的某个元素。

当创建了ViewModel后,双向绑定是如何达成的呢?

首先,我们将上图中的DOM Listeners和Data Bindings看作两个工具,它们是实现双向绑定的关键。
从View侧看,ViewModel中的DOM Listeners工具会帮我们监测页面上DOM元素的变化,如果有变化,则更改Model中的数据;
从Model侧看,当我们更新Model中的数据时,Data Bindings工具会帮我们更新页面中的DOM元素。

Hello World示例

了解一门语言,或者学习一门新技术,编写Hello World示例是我们的必经之路。
这段代码在画面上输出"Hello World!"。

<!DOCTYPE
html>

<html>

<head>

<meta charset="UTF-8">

<title></title>

</head>

<body>

<!--这是我们的View-->

<div id="app">

{{ message }}

</div>

</body>

<script src="js/vue.js"></script>

<script>

// 这是我们的Model

var exampleData = {

message: 'Hello World!'

}

// 创建一个 Vue 实例或
"ViewModel"

// 它连接 View 与 Model

new Vue({

el: '#app',

data: exampleData

})

</script>

</html>

使用Vue的过程就是定义MVVM各个组成部分的过程的过程。

  1. 定义View
  2. 定义Model
  3. 创建一个Vue实例或"ViewModel",它用于连接View和Model

在创建Vue实例时,需要传入一个选项对象,选项对象可以包含数据、挂载元素、方法、模生命周期钩子等等。

在这个示例中,选项对象el属性指向View,el:
'#app'表示该Vue实例将挂载到<div
id="app">...</div>这个元素;data属性指向Model,data: exampleData表示我们的Model是exampleData对象。
Vue.js有多种数据绑定的语法,最基础的形式是文本插值,使用一对大括号语法,在运行时{{ message
}}会被数据对象的message属性替换,所以页面上会输出"Hello
World!"。

Vue.js已经更新到2.0版本了,但由于还不是正式版,本文的代码都是1.0.25版本的。

双向绑定示例

MVVM模式本身是实现了双向绑定的,在Vue.js中可以使用v-model指令在表单元素上创建双向数据绑定。

<!--这是我们的View-->

<div id="app">

<p>{{ message }}</p>

<input type="text"
v-model="message"/>

</div>

将message绑定到文本框,当更改文本框的值时,<p>{{ message }}</p> 中的内容也会被更新。

反过来,如果改变message的值,文本框的值也会被更新,我们可以在Chrome控制台进行尝试。

Vue实例的data属性指向exampleData,它是一个引用类型,改变了exampleData对象的属性,同时也会影响Vue实例的data属性。

Vue.js的常用指令

上面用到的v-model是Vue.js常用的一个指令,那么指令是什么呢?

Vue.js的指令是以v-开头的,它们作用于HTML元素,指令提供了一些特殊的特性,将指令绑定在元素上时,指令会为绑定的目标元素添加一些特殊的行为,我们可以将指令看作特殊的HTML特性(attribute)。

Vue.js提供了一些常用的内置指令,接下来我们将介绍以下几个内置指令:

  • v-if指令
  • v-show指令
  • v-else指令
  • v-for指令
  • v-bind指令
  • v-on指令

Vue.js具有良好的扩展性,我们也可以开发一些自定义的指令,后面的文章会介绍自定义指令。

v-if指令

v-if是条件渲染指令,它根据表达式的真假来删除和插入元素,它的基本语法如下:

v-if="expression"

expression是一个返回bool值的表达式,表达式可以是一个bool属性,也可以是一个返回bool的运算式。例如:

<!DOCTYPE
html>

<html>

<head>

<meta charset="UTF-8">

<title></title>

</head>

<body>

<div id="app">

<h1>Hello, Vue.js!</h1>

<h1 v-if="yes">Yes!</h1>

<h1 v-if="no">No!</h1>

<h1 v-if="age >= 25">Age:
{{ age }}</h1>

<h1 v-if="name.indexOf('jack') >=
0">Name: {{ name }}</h1>

</div>

</body>

<script src="js/vue.js"></script>

<script>

var vm = new Vue({

el: '#app',

data: {

yes: true,

no: false,

age: 28,

name: 'keepfool'

}

})

</script>

</html>

注意:yes, no, age, name这4个变量都来源于Vue实例选项对象的data属性。

这段代码使用了4个表达式:

  • 数据的yes属性为true,所以"Yes!"会被输出;
  • 数据的no属性为false,所以"No!"不会被输出;
  • 运算式age >= 25返回true,所以"Age: 28"会被输出;
  • 运算式name.indexOf('jack') >= 0返回false,所以"Name: keepfool"不会被输出。

注意:v-if指令是根据条件表达式的值来执行元素的插入或者删除行为。

这一点可以从渲染的HTML源代码看出来,面上只渲染了3个<h1>元素,v-if值为false的<h1>元素没有渲染到HTML。

为了再次验证这一点,可以在Chrome控制台更改age属性,使得表达式age >= 25的值为false,可以看到<h1>Age: 28</h1>元素被删除了。

age是定义在选项对象的data属性中的,为什么Vue实例可以直接访问它呢?
这是因为每个Vue实例都会代理其选项对象里的data属性。

v-show指令

v-show也是条件渲染指令,和v-if指令不同的是,使用v-show指令的元素始终会被渲染到HTML,它只是简单地为元素设置CSS的style属性。

<!DOCTYPE
html>

<html>

<head>

<meta charset="UTF-8">

<title></title>

</head>

<body>

<div id="app">

<h1>Hello, Vue.js!</h1>

<h1 v-show="yes">Yes!</h1>

<h1 v-show="no">No!</h1>

<h1 v-show="age >=
25">Age: {{ age }}</h1>

<h1 v-show="name.indexOf('jack')
>= 0">Name: {{ name }}</h1>

</div>

</body>

<script src="js/vue.js"></script>

<script>

var vm = new Vue({

el: '#app',

data: {

yes: true,

no: false,

age: 28,

name: 'keepfool'

}

})

</script>

</html>

在Chrome控制台更改age属性,使得表达式age >= 25的值为false,可以看到<h1>Age: 24</h1>元素被设置了style="display:none"样式。

v-else指令

可以用v-else指令为v-if或v-show添加一个“else块”。v-else元素必须立即跟在v-if或v-show元素的后面——否则它不能被识别。

<!DOCTYPE
html>

<html>

<head>

<meta charset="UTF-8">

<title></title>

</head>

<body>

<div id="app">

<h1 v-if="age >= 25">Age:
{{ age }}</h1>

<h1 v-else>Name: {{ name }}</h1>

<h1>---------------------分割线---------------------</h1>

<h1 v-show="name.indexOf('keep')
>= 0">Name: {{ name }}</h1>

<h1 v-else>Sex: {{ sex }}</h1>

</div>

</body>

<script src="js/vue.js"></script>

<script>

var vm = new Vue({

el: '#app',

data: {

age: 28,

name: 'keepfool',

sex: 'Male'

}

})

</script>

</html>

v-else元素是否渲染在HTML中,取决于前面使用的是v-if还是v-show指令。


这段代码中v-if为true,后面的v-else不会渲染到HTML;v-show为tue,但是后面的v-else仍然渲染到HTML了。

v-for指令

v-for指令基于一个数组渲染一个列表,它和JavaScript的遍历语法相似:

v-for="item in
items"

items是一个数组,item是当前被遍历的数组元素。

隐藏代码

<!DOCTYPE
html>

<html>

<head>

<meta charset="UTF-8">

<title></title>

<link rel="stylesheet"
href="styles/demo.css" />

</head>

<body>

<div id="app">

<table>

<thead>

<tr>

<th>Name</th>

<th>Age</th>

<th>Sex</th>

</tr>

</thead>

<tbody>

<tr v-for="person in
people">

<td>{{ person.name  }}</td>

<td>{{ person.age  }}</td>

<td>{{ person.sex  }}</td>

</tr>

</tbody>

</table>

</div>

</body>

<script src="js/vue.js"></script>

<script>

var vm = new Vue({

el: '#app',

data: {

people: [{

name: 'Jack',

age: 30,

sex: 'Male'

}, {

name: 'Bill',

age: 26,

sex: 'Male'

}, {

name: 'Tracy',

age: 22,

sex: 'Female'

}, {

name: 'Chris',

age: 36,

sex: 'Male'

}]

}

})

</script>

</html>

我们在选项对象的data属性中定义了一个people数组,然后在#app元素内使用v-for遍历people数组,输出每个person对象的姓名、年龄和性别。

v-bind指令

v-bind指令可以在其名称后面带一个参数,中间放一个冒号隔开,这个参数通常是HTML元素的特性(attribute),例如:v-bind:class

v-bind:argument="expression"

下面这段代码构建了一个简单的分页条,v-bind指令作用于元素的class特性上。
这个指令包含一个表达式,表达式的含义是:高亮当前页。

<!DOCTYPE
html>

<html>

<head>

<meta charset="UTF-8">

<title></title>

<link rel="stylesheet"
href="styles/demo.css" />

</head>

<body>

<div id="app">

<ul class="pagination">

<li v-for="n in pageCount">

<a href="javascripit:void(0)"
v-bind:class="activeNumber === n + 1 ? 'active' : ''">{{ n + 1 }}</a>

</li>

</ul>

</div>

</body>

<script src="js/vue.js"></script>

<script>

var vm = new Vue({

el: '#app',

data: {

activeNumber: 1,

pageCount: 10

}

})

</script>

</html>

注意v-for="n
in pageCount"这行代码,pageCount是一个整数,遍历时n从0开始,然后遍历到pageCount
–1结束。

v-on指令

v-on指令用于给监听DOM事件,它的用语法和v-bind是类似的,例如监听<a>元素的点击事件:

<a v-on:click="doSomething">

有两种形式调用方法:绑定一个方法(让事件指向方法的引用),或者使用内联语句。
Greet按钮将它的单击事件直接绑定到greet()方法,而Hi按钮则是调用say()方法。

<!DOCTYPE
html>

<html>

<head>

<meta charset="UTF-8">

<title></title>

</head>

<body>

<div id="app">

<p><input type="text"
v-model="message"></p>

<p>

<!--click事件直接绑定一个方法-->

<button
v-on:click="greet">Greet</button>

</p>

<p>

<!--click事件使用内联语句-->

<button
v-on:click="say('Hi')">Hi</button>

</p>

</div>

</body>

<script src="js/vue.js"></script>

<script>

var vm = new Vue({

el: '#app',

data: {

message: 'Hello, Vue.js!'

},

// 在 `methods` 对象中定义方法

methods: {

greet: function() {

// // 方法内 `this` 指向 vm

alert(this.message)

},

say: function(msg) {

alert(msg)

}

}

})

</script>

</html>

v-bind和v-on的缩写

Vue.js为最常用的两个指令v-bind和v-on提供了缩写方式。v-bind指令可以缩写为一个冒号,v-on指令可以缩写为@符号。

<!--完整语法-->

<a href="javascripit:void(0)"
v-bind:class="activeNumber === n + 1 ? 'active' : ''">{{ n + 1 }}</a>

<!--缩写语法-->

<a href="javascripit:void(0)"
:class="activeNumber=== n + 1 ? 'active' : ''">{{ n + 1 }}</a>

<!--完整语法-->

<button
v-on:click="greet">Greet</button>

<!--缩写语法-->

<button @click="greet">Greet</button>

综合示例

现在我们已经介绍了一些Vue.js的基础知识了,结合以上知识我们可以来做个小Demo。

<!DOCTYPE
html>

<html>

<head>

<meta charset="UTF-8">

<title></title>

<link rel="stylesheet"
href="styles/demo.css" />

</head>

<body>

<div id="app">

<fieldset>

<legend>

Create New Person

</legend>

<div class="form-group">

<label>Name:</label>

<input type="text"
v-model="newPerson.name"/>

</div>

<div class="form-group">

<label>Age:</label>

<input type="text" v-model="newPerson.age"/>

</div>

<div class="form-group">

<label>Sex:</label>

<select
v-model="newPerson.sex">

<option value="Male">Male</option>

<option
value="Female">Female</option>

</select>

</div>

<div class="form-group">

<label></label>

<button
@click="createPerson">Create</button>

</div>

</fieldset>

<table>

<thead>

<tr>

<th>Name</th>

<th>Age</th>

<th>Sex</th>

<th>Delete</th>

</tr>

</thead>

<tbody>

<tr v-for="person in
people">

<td>{{ person.name }}</td>

<td>{{ person.age }}</td>

<td>{{ person.sex }}</td>

<td :class="'text-center'"><button
@click="deletePerson($index)">Delete</button></td>

</tr>

</tbody>

</table>

</div>

</body>

<script src="js/vue.js"></script>

<script>

var vm = new Vue({

el: '#app',

data: {

newPerson: {

name: '',

age: 0,

sex: 'Male'

},

people: [{

name: 'Jack',

age: 30,

sex: 'Male'

}, {

name: 'Bill',

age: 26,

sex: 'Male'

}, {

name: 'Tracy',

age: 22,

sex: 'Female'

}, {

name: 'Chris',

age: 36,

sex: 'Male'

}]

},

methods:{

createPerson: function(){

this.people.push(this.newPerson);

// 添加完newPerson对象后,重置newPerson对象

this.newPerson = {name: '', age: 0, sex: 'Male'}

},

deletePerson: function(index){

// 删一个数组元素

this.people.splice(index,1);

}

}

})

</script>

</html>

vue快速入门的更多相关文章

  1. vue 快速入门 系列 —— 虚拟 DOM

    其他章节请看: vue 快速入门 系列 虚拟 DOM 什么是虚拟 dom dom 是文档对象模型,以节点树的形式来表现文档. 虚拟 dom 不是真正意义上的 dom.而是一个 javascript 对 ...

  2. vue 快速入门 系列

    vue 快速入门(未完结,持续更新中...) 前言 为什么要学习 vue 现在主流的框架 vue.angular 和 react 都是声明式操作 DOM 的框架.所谓声明式,就是我们只需要描述状态与 ...

  3. vue 快速入门 系列 —— 初步认识 vue

    其他章节请看: vue 快速入门 系列 初步认识 vue vue 是什么 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架. 所谓渐进式,就是你可以一步一步.有阶段 ...

  4. vue 快速入门 系列 —— 侦测数据的变化 - [基本实现]

    其他章节请看: vue 快速入门 系列 侦测数据的变化 - [基本实现] 在 初步认识 vue 这篇文章的 hello-world 示例中,我们通过修改数据(app.seen = false),页面中 ...

  5. vue 快速入门 系列 —— 侦测数据的变化 - [vue 源码分析]

    其他章节请看: vue 快速入门 系列 侦测数据的变化 - [vue 源码分析] 本文将 vue 中与数据侦测相关的源码摘了出来,配合上文(侦测数据的变化 - [基本实现]) 一起来分析一下 vue ...

  6. vue 快速入门 系列 —— vue 的基础应用(上)

    其他章节请看: vue 快速入门 系列 vue 的基础应用(上) Tip: vue 的基础应用分上下两篇,上篇是基础,下篇是应用. 在初步认识 vue一文中,我们已经写了一个 vue 的 hello- ...

  7. vue 快速入门 系列 —— vue 的基础应用(下)

    其他章节请看: vue 快速入门 系列 vue 的基础应用(下) 上篇聚焦于基础知识的介绍:本篇聚焦于基础知识的应用. 递归组件 组件是可以在它们自己的模板中调用自身的.不过它们只能通过 name 选 ...

  8. vue 快速入门 系列 —— vue loader 上

    其他章节请看: vue 快速入门 系列 vue loader 上 通过前面"webpack 系列"的学习,我们知道如何用 webpack 实现一个不成熟的脚手架,比如提供开发环境和 ...

  9. vue 快速入门 系列 —— vue loader 下

    其他章节请看: vue 快速入门 系列 vue loader 下 CSS Modules CSS Modules 是一个流行的,用于模块化和组合 CSS 的系统.vue-loader 提供了与 CSS ...

  10. vue 快速入门 系列 —— vue loader 扩展

    其他章节请看: vue 快速入门 系列 vue loader 扩展 在vue loader一文中,我们学会了从零搭建一个简单的,用于单文件组件开发的脚手架.本篇将在此基础上继续引入一些常用的库:vue ...

随机推荐

  1. SpringMVC 与 REST.

    一.REST 的基础知识 我敢打赌这并不是你第一次听到或读到REST这个词.当讨论REST时,有一种常见的错误就是将其视为“基于URL的Web服务”—— 将REST作为另一种类型的RPC机制,只不过是 ...

  2. 为啥JQuery被淘汰了?

    摘要: 技术进步永不止步. 原文:jQuery的没落和技术发展的一般规律 作者:凌霄光 Fundebug经授权转载,版权归原作者所有. jQuery的成就 jQuery是一个伟大的库, 它解决了dom ...

  3. Codeforces617E(莫队)

    E. XOR and Favorite Number time limit per test: 4 seconds memory limit per test: 256 megabytes input ...

  4. 输出映射resultType

    √1:简单类型 √2:简单类型列表 √3:POJO类型只有列名或列名的别名与POJO的属性名一致,该列才可以映射成功只要列名或列名的别名与POJO的属性名有一个一致,就会创建POJO对象如果列名或列名 ...

  5. canvas-a11htmlANDcanvas.html

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. JS ES6中的箭头函数(Arrow Functions)使用

    转载这篇ES6的箭头函数方便自己查阅. ES6可以使用“箭头”(=>)定义函数,注意是函数,不要使用这种方式定义类(构造器). 一.语法 基础语法 (参数1, 参数2, …, 参数N) => ...

  7. 基于Docker的TensorFlow机器学习框架搭建和实例源码解读

    概述:基于Docker的TensorFlow机器学习框架搭建和实例源码解读,TensorFlow作为最火热的机器学习框架之一,Docker是的容器,可以很好的结合起来,为机器学习或者科研人员提供便捷的 ...

  8. 使用fiddler抓包手机请求数据

    1.启动Fiddler,打开菜单栏中的 Tools > Fiddler Options,打开“Fiddler Options”对话框. 2.在Fiddler Options”对话框切换到“Con ...

  9. gitlab汉化

    是上一片,我已经介绍了,如何安装gitlab 这篇文章讲解一下如何安装使用汉化gitlab 如需要查看如何安装gitlab,请访问:https://www.cnblogs.com/ws17345067 ...

  10. 关于ARM CM3的启动文件分析

    下面以ARM Cortex_M3裸核的启动代码为例,做一下简单的分析.首先,在启动文件中完成了三项工作: 1.  堆栈以及堆的初始化 2.  定位中断向量表 3.  调用Reset Handler. ...