目录:
Vue.js 使用了基于 HTML 的模板语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据。所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器和 HTML 解析器解析。vue将模板编译成虚拟dom,
结合响应系统,Vue 能够智能地计算出最少需要重新渲染多少组件,并把 DOM 操作次数减到最少。
html模板语法:
这是一种基于字符串的模板技术,以字符串和数据为输入,通过用正则表达式将占位符替换为所需数据的方式,构建出完整的 HTML 字符串。
data: {
html: ''
}
HTML属性中的值应使用v-bind指令。类型与jQuery中的$("#xxx").attr(propName, propVal)
示例,以修改元素的class属性为例:
定义一个样式
在data中定义一个属性,其值为上面定义的样式名
data: {
red: 'redClass'
}
在html使用v-bind指令设置样式
设置之前: aaaa
设置之后: aaa
{{str.substr(0,6).toUpperCase()}}
data: {
str: 'hello vue'
}
{{ number + 1 }}
data: {
number: 10
}
{{ ok ? 'YES' : 'NO' }}
data: {
ok: true
}
data: {
bookId: 'book001',
id: 'book002'
}
type == A
type == B
other value
var vm = new Vue({
el: '#app',
data: {
type: 'C'
}
});
注: js = == === 之间的区别
一个等号是赋值操作,==先转换类型再比较,===先判断类型,如果不是同一类型直接为false
alert(1 == “1”); // true
alert(1 === “1”); // false
show == yes
var vm = new Vue({
el: '#app',
data: {
show: 'yes'
}
});
{{item.name}} -- {{item.id}}
{{key}}-{{o}}
var vm = new Vue({
el: '#app',
data: {
itmes:[
{name: 'zs',age:18},
{name: 'ww',age:19},
{name: 'ls',age:20},
{name: 'zl',age:21}
],
obj: {
name:'张三',
age: 21,
addr: '湖南长沙'
}
}
});
{{index}}:{{item.name}}
var vm = new Vue({
el: '#app',
data: {
type: 'C',
show: 'no',
items:[
{name: '长沙',id:18},
{name: '昆明',id:19},
{name: '武汉',id:20},
{name: '南京',id:21}
],
obj: {
name:'张三',
age: 21,
addr: '湖南长沙'
},
selected:[]
},
methods: {
getSelected: function() {
console.log(this.selected);
}
}
});
注意:在动态参数中,作为参数的变量名(如:attrname)要全部小写,否则无效 !!
var vm = new Vue({
el: '#app',
data: {
url: 'https://www.baidu.com',
attrname:'href',
evname: 'click'
},
methods: {
clickme: function() {
console.log("点到我了");
}
}
});
指令 |
简写 |
示例 |
---|---|---|
v-bind:xxx |
:xxx |
v-bind:href 简写为 :href |
v-on:xxx |
@xxx |
v-on:click 简写为 @click |
var vm = new Vue({
filters: {
'filterName': function(value) {
//过滤器实现
}
}
});
{{ name | capitalize }}
{{msg | toUpperCase}}
var vm = new Vue({
el: '#app',
data: {
msg:"hello vue"
},
//局部过滤器
filters:{
toUpperCase: function(value) {
return value.toUpperCase();
}
}
});
//全局过滤器
Vue.filter('fmtDate',function(value) {
return fmtDate(value, 'yyyy年MM月dd日')
});
{{date | fmtDate}}
computed:{
xxx:function(){
}
}
var vm = new Vue({
el: '#app',
data: {
//定义测试数据
books: [
{name:'红楼梦', price:"120"},
{name:'三国演义', price:"100"},
{name:'水浒传', price:"90"},
]
},
//计算属性
computed: {
compTotal: function() {
let sum = 0;
for(index in this.books) {
sum += parseInt(this.books[index].price);
}
return sum;
}
}
});
{{book.name}} -> {{book.price}}
总价:{{compTotal}}
关于var 与 let
var声明为全局属性
let为ES6新增,可以声明块级作用域的变量(局部变量)
建议使用let声明变量
watch: {
xxxx: function(val) {
//监听器实现
}
}
var vm = new Vue({
el: '#app',
data: {
m: 1,
cm: 100
},
//设置监听属性
watch: {
m: function(val) {
if(val)
this.cm = parseInt(val) * 100;
else
this.cm = "";
},
cm: function(val) {
if(val)
this.m = parseInt(val) / 100;
else
this.m = "";
}
}
});
vue是一个mvvm框架,即数据双向绑定,即当数据发生变化的时候,视图也就发生变化,当视图发生变化的时候,数据也会跟着同步变化。这也算是vue的精髓之处了。值得注意的是,我们所说的数据双向绑定,一定是对于UI控件来说的,非UI控件不会涉及到数据双向绑定。 单向数据绑定是使用状态管理工具(如redux)的前提。如果我们使用vuex,那么数据流也是单项的,这时就会和双向数据绑定有冲突,我们可以这么解决。
米:
厘米: