1.{{message}}輸出data數據中的message。
2.v-for="todo in todos"輸出data數據中的dotos數組
3.v-on:click="aaaa"綁定methods中的aaaa()事件,可以簡寫為@click
4.v-model="input" 輸出data數據中input的值,雙向綁定。
5.this.$dispatch("aaa", this.msg)向上派發事件,aaa寫在events中
6.:id="branch"表示id的值由data數據中的branch決定,通常用於for循環
<template v-for="branch in branches">
<!--:為傳入的branch值-->
<input type="radio" name="branch" :id="branch" :value="branch" v-model="currentBranch"><label :for="branch">{{branch}}</label>
</template>
7.:class="{bold: isFolder}"或:class="{isFolder1 > 0 ? 'aaa1' : 'bbb1' }"表示當isFolder為true時class=bold。
8.v-show="open"表示當open為true時顯示
9.v-if="isFolder"表示當isFolder為true時顯示
10.v-show與v-if的區別為當元素不顯示時,v-show可以將data中的open設置為false,實現雙向數據綁定
11.子組件獲取數據的方式
例:在父級中設置<item class="item" :model="treeData"></item>
子級中使用
Vue.compoent("item", {
props: ['model']
...
})
的方式獲取
12.created:生命周期,DOM還未形成之前
13.computed:生命周期,在例如:class="{bold: isFolder}中的isFolder是true還是false的時候執行
14.在子級下的數據data的寫法為
data:function() {
return {
open: false
}
}
以上的return值表示open的獲取,不表示將open返回到父級,與雙向綁定無關.
var Person = Vue.extend({
template: "<div><span>name: </span>{{name}}<span>age: </span>{{age}}</div>",
data: function() {
return {
name: "lili",
age: 22
}
}
});
15.{{key | filter}}表示key通過filters中的filter()函數進行過濾
16.v-for="entry in data | filterBy filterKey"表示在循環中直接進行數據過濾
16.debounce="300"表示延遲執行300ms
17.v-html相當於
<div v-html="html"></div>
<!-- 相同 -->
<div>{{{html}}}</div>
即可以輸出html的標簽,在表單提交的時候不使用,防止xss攻擊
18.watch表示監聽
watch: {
currentBranch: 'fetchData'
}
當打他數據中的currentBranch發生改變時,執行fetchData函數
19.slot的使用
<div class="modal-header">
<slot name="header">
default header
</slot>
</div>
<div class="modal-body">
<slot name="body">
default body
</slot>
</div>
<h3 slot="header">custom header</h3>
slot會將defaut中的default header變為custom header。
20.sync實現雙向數據綁定,將父級通過props傳入到子級中的變量通過子級進行修改,雙向綁定后會改變父級中的對應傳到子級的那個變量
21.transition添加css屬性實現動態效果
例一個class="expand"的屬性
.expand-transition {
transition: all .3s ease;
height: 30px;
padding: 10px;
background-color: #eee;
overflow: hidden;
}//表示正常情況下的效果
.expand-enter, .expand-leave {
height: 0;
padding: 0 10px;
opacity: 0;
}//元素在消失或顯示的時候展示的效果
<div transition="expand"></div>直接寫在html標簽中
<div v-if="show" :transition="transitionName">hello</div>
new Vue({
el: '...',
data: {
show: false,
transitionName: 'expand'
}
})
//寫在Vue里
寫在Vue里
22.
var data = {a: 1};
var vm = new Vue({
el: '#app',
data: data
})
console.log(vm.a === data.a);//true
vm.a = 2;
console.log(data.a);//2
data.a = 3;
console.log(vm.a);//3
23.v-for循環輸出,點擊事件可以通過設置參數獲取位置
例:<button v-on:click="removeTodo($index)">X</button>
23.子級下的子級添加組件的方式
例:
var Person = Vue.extend({});
var Contact = Vue.extend({
template: "<person></person>",
components: {
'person': Person
}
})

