1.双向绑定 v-model
实例:
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> </head> <body> <div id="app"> <p>{{ message }}</p> <input type="text" v-model="message"/> </div> </body> <script src="js/vue/vue.min .js"></script> <script type="text/javascript"> var exampleDate={ message:'hello World!' } new Vue({ el:"#app", data:exampleDate }) </script> </html>
2.Vue.js的常用指令
v-if指令
实例:
<!DOCTYPE html> <html> <head lang="en"> <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>=20">Age:{{ age }}}</h1> <h1 v-if="name.indexOf('jack')>=0">Name:{{ name }}}</h1> </div> </body> <script src="js/vue/vue.min .js"></script> <script type="text/javascript"> var vm= new Vue({ el:"#app", data:{ yes:true, no:false, age:23, name:'hjdfd.jack', } }) </script> </html>
这段代码使用了4个表达式:
数据的
yes
属性为true,所以"Yes!"会被输出;数据的
no
属性为false,所以"No!"不会被输出;运算式
age >= 20
返回true,所以"Age: 23"会被输出;运算式
!注意:v-if指令是根据条件表达式的值来执行元素的插入或者删除行为。没有显示的值相当于被注释掉了<!-- -->name.indexOf('jack') >= 0
返回false,所以"Name: hjdfd.jack"会被输出。
v-show指令
v-show
也是条件渲染指令,和v-if指令不同的是,使用v-show
指令的元素始终会被渲染到HTML,它只是简单地为元素设置CSS的style属性。<!DOCTYPE html> <html> <head lang="en"> <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>=20">Age:{{ age }}}</h1> <h1 v-show="name.indexOf('jack')>=0">Name:{{ name }}}</h1> </div> </body> <script src="js/vue/vue.min .js"></script> <script type="text/javascript"> var vm= new Vue({ el:"#app", data:{ yes:true, no:false, age:23, name:'hjdfd.jack', } }) </script> </html>v-show指令如果没有显示相当于style="display: none;"
v-else指令
可以用v-else
指令为v-if
或v-show
添加一个“else块”。v-else
元素必须立即跟在v-if
或v-show
元素的后面——否则它不能被识别。
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> </head> <body> <div id="app"> <h1 v-if="age >= 22">Age: {{ age }}</h1> <h1 v-else>Name: {{ name }}</h1> <h1>---------------------分割线---------------------</h1> <h1 v-show="name.indexOf('jack') >= 0">Name: {{ name }}</h1> <h1 v-else>Sex: {{ sex }}</h1> </div> </body> <script src="js/vue/vue.min .js"></script> <script type="text/javascript"> var vm= new Vue({ el:"#app", data:{ age:25, name:'hjdfd.jack', 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 lang="en"> <meta charset="UTF-8"> <title></title> </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/vue.min .js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { people: [{ name: 'Jack', age: 20, sex: 'Male' }, { name: 'lisi', age: 23, sex: 'Male' }, { name: 'zhangsan', age: 25, sex: 'Female' }, { name: 'wangwu', age: 29, sex: 'Male' }] } }) </script> </html>
v-bind指令
v-bind 主要用于属性绑定,Vue官方提供了一个简写方式 :bind,例如:
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> </head> <body> <div id="app"> <a v-bind:href="wangzhi">wangzhi</a> </div> </body> <script src="js/vue/vue.min .js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { wangzhi:'http://www.baidu.com' } }) </script> </html>