基本语法
<div id="app">
{{ message }}
</div>
div的id是app,内容为一个名为message的变量
在js代码块内:
var app = new Vue({
el: '#app',
data: {
message: 'Hello Vue!'
}
})
声明一个名为app的对象,该对象是一个vue对象,其中element使用id选择器,选择了id为app的代码
块,并为变量message赋值"hello vue"
完成渲染后即可看到页面上出现"Hello Vue"这行字
创建Vue实例
var vm = new Vue({
})
示例
var data = { a: 1 }
var vm = new Vue({
data: data
})
vm.a == data.a
vm.a = 2
data.a
data.a = 3
vm.a
生命周期
每个 Vue 实例在被创建时都要经过一系列的初始化过程
生命周期钩子 函数可以让用户在实例化的过程中进行一些操作
beforeCreate – created – beforeMount – mounted – beforeDestroy – destroyed
除此之外,在data更新时,存在beforeUpdate 和 updated 两个阶段
调用生命周期钩子的示例如下:
<script type="text/javascript">
var vm = new Vue({
el: '#app',
data: {
msg : "hi vue",
a : 'hihi'
},
beforeCreate:function(){
console.log('beforeCreate');
},
created:function(){
console.log('created')
},
beforeMount:function(){
console.log('beforeMount')
},
mounted:function(){
console.log('mounted')
},
beforeUpdate:function(){
console.log('beforeUpdate')
},
updated:function(){
console.log('updated')
}
});
vm.$watch('a',function(newval,oldval){
console.log(newval,oldval)
})
setTimeout(function() {
vm.msg = 'change...'
}, 3000);
</script>
语法
插值
常常使用{{}}来插值
<span>Message: {{ msg }}</span>
使用 v-once指令,可以使插值为一次性的
<span v-once>不变的: {{ msg }}</span>
使用指令v-html来输出html元素而非字符串
<div id="app">
{{msg}}
<p>这是字符串:{{rawHtml}}</p>
<p v-html="rawHtml"></p>
</div>
<script type="text/javascript">
var vm = new Vue({
el: '#app',
data: {
msg : "hi vue",
rawHtml : '<span style="color:red">这应该是红色的</span>'
},
})
</script>
结果
Mustache语法不能作用在HTML特性上,需要使用v-bind指令
<div v-bind:class="color"></div>
这里对该标签的class进行了绑定,绑定了color这个属性,此时我们可以在vue对象中对该特性赋值
data: {
msg : "hi vue",
rawHtml : '<span style="color:red">这应该是红色的</span>',
color : 'red'
},
那么,div的class名称就是"red"了,可以使用css样式对.red进行设定
<p>{{ number + 1 }}</p>
若在vue类中给number赋值10,则页面上会输出11
<p>{{ ok ? 'yes' : 'no'}}</p>
三元运算符,对ok进行赋值
<p>{{ message.split('').reverse().join('') }}</p>
字符串表达式,对message赋值
指令
指令是带有v-的特殊特性
指令的作用是在表达式的值变化改变时,将其影响于dom
例子
<p v-if='seen'>看到了吗</p>
v-if 根据表达式 seen 的真假来决定是否显示该元素
参数
一些指令能够接受参数
<a v-bind:herf='url'>...</a>
该指令将herf属性与url绑定,在vue中对url进行赋值,该超链接即链接到url指定的网址
修饰符
以.指明的特殊后缀,用于指出一个指令应该以特殊的方式绑定
例如 .prevent 修饰符告诉v-on指令对触发的事件调用event.preventDefault()
<form v-on:submit.prevent="onSubmit">...</form>
再例如,一个点击事件
<div @click="click1">
<div @click.stop="click2">
点我
</div>
</div>
在没有.stop修饰的情况下,点击“点我”将触发两个click事件,但如果使用了.stop,就不会触发click1事件
class与style绑定
使用v-bind:class="…"可以实现动态class
<div id="app">
<div
class="test"
v-bind:class="{active:isActive}"
style="width: 200px;height: 200px;text-align: center;line-height: 200px;">
hi Vue
</div>
</div>
如上图,div元素的class与{active:isActive}进行了绑定
active是css样式,即isActive的真假决定了该div是否使用该样式
同时可以看到,静态的样式test与动态样式是可以共存的
也可以在动态样式中添加多个样式
数组写法:
v-bind:class="[isActive ? 'active' : '']"
使用三元运算符即可实现
style绑定
例子
<div
:style="{color : color,fontsize:size}">
hi vue
</div>
通过style,可以设置color变量和size变量,在vue类中对这两个变量赋值即可改变样式
同样可以使用三元运算符
<div
:style="{color : color,fontsize:size,background:isRed ? '#FF000' : ''}">
hi vue
</div>
|