### 一、Vue3.x模板中使用JavaScript表達式
**業務邏輯:**
~~~
data() {
return {
number: 1
}
}
~~~
**template模板**:
~~~
{{ number + 1 }}
{{ ok ? 'YES' : 'NO' }}
{{ message.split('').reverse().join('')}}
~~~
### 二、 v-if v-else v-else-if v-show
#### 2.1 v-if
**業務邏輯:**
~~~
data() {
return {
flag: 1
}
}
~~~
**template模板**:
~~~
<p v-if="flag">v-if flag=true</p>
~~~
#### 2.2 v-if v-else
~~~
<div v-if="Math.random() > 0.5">
大于0.5
</div>
<div v-else>
小于0.5
</div>
~~~
`v-else` 元素必須緊跟在帶 `v-if` 或者 `v-else-if` 的元素的后面,否則它將不會被識別。
#### 2.3、v-else-if
~~~
<div v-if="type === 'A'">
A
</div>
<div v-else-if="type === 'B'">
B
</div>
<div v-else-if="type === 'C'">
C
</div>
<div v-else>
Not A/B/C
</div>
~~~
與相似`v-else`,`v-else-if`元素必須緊隨`v-if`或`v-else-if`元素
#### 2.4、在`<template>`元素上使用 v-if 條件渲染分組
因為 `v-if` 是一個指令,所以必須將它添加到一個元素上。但是如果想切換多個元素呢?此時可以把一個 `<template>` 元素當做不可見的包裹元素,并在上面使用 `v-if`。最終的渲染結果將不包含 `<template>` 元素。
~~~
<template v-if="ok">
<h1>Title</h1>
<p>Paragraph 1</p>
<p>Paragraph 2</p>
</template>
~~~
#### 2.5、v-show
另一個用于根據條件展示元素的選項是 `v-show` 指令
~~~
<h1 v-show="ok">Hello!</h1>
~~~
#### 2.6、v-if 和 v-show的區別
v-if是dom操作,v-show只是css的顯示隱藏,一般來說,`v-if` 有更高的切換開銷,而 `v-show` 有更高的初始渲染開銷。因此,如果需要非常頻繁地切換,則使用 `v-show` 較好。
### 三、計算屬性
#### 3.1 計算屬性入門
1、在模板中表達式非常便利,但是它們實際上只用于簡單的操作。
2、模板是為了描述視圖的結構。在模板中放入太多的邏輯會讓模板過重且難以維護。這就是為什么 Vue.js 將綁定表達式限制為一個表達式。如果需要多于一個表達式的邏輯,應當使用計算屬性。
**業務邏輯:**
~~~
export default {
data() {
return {
a: 12,
flag: true,
message: "三國演義"
};
},
computed: {
reverseMsg() {
return this.message.split("").reverse().join("")
}
},
methods: {
setMsg() {
this.message = "大家好"
}
}
};
~~~
**template模板**:
~~~
<template>
{{reverseMsg}}
<button @click="setMsg()">改變數據</button>
</template>
~~~
#### 3.2、計算屬性實現數據的篩選
~~~
export default {
data() {
return {
a: 12,
flag: true,
message: "三國演義",
list:['apple','banana','orange','pear']
};
},
computed: {
reverseMsg() {
return this.message.split("").reverse().join("")
},
searchList() {
var tempArr = [];
this.listData.forEach((value) => {
if (value.indexOf(this.keyword) != -1 && this.keyword != "") {
tempArr.push(value)
}
})
console.log(tempArr)
return tempArr;
}
},
methods: {
setMsg() {
this.message = "大家好"
}
}
};
~~~
~~~
<template>
<input type="text" v-model="keyword" placeholder="請輸入關鍵詞" />
<ul>
<li v-for="(item,index) in searchList" :key="index">{{item}}</li>
</ul>
</template>
~~~
### 四、watch監聽數據變化
Vue.js 提供了一個方法 watch ,它用于觀察 Vue 實例上的數據變動。當一些數據需要根據其它數據變化時,watch 很誘人 —— 特別是如果你來自 AngularJS 。不過,通常更好的辦法是使用計算屬性而不是一個命令式的 watch 回調。
**業務邏輯:**
~~~
export default {
data() {
return {
firstName: "",
lastName: "",
fullName: ""
};
},
watch: {
firstName: function (val) {
this.fullName = val + this.lastName;
},
lastName: function (val) {
this.fullName = this.firstName + val;
}
}
};
~~~
**template模板**:
~~~
<input type="text" v-model="firstName">
<input type="text" v-model="lastName">
{{ fullName }}
~~~
- 空白目錄
- 第一節 Vue3.x教程、Vue3.x簡介、搭建Vue3.x環境、創建運行Vue3.x項目、分析Vue目錄結構
- 第二節 Vue3.x綁定數據、綁定html、綁定屬性、循環數據
- 第三節 Vue3.x中的事件方法入門、模板語法模板中類和樣式綁定
- 第四節 Vue3.x中的事件方法詳解、事件監聽、方法傳值、事件對象、多事件處理程序、事件修飾符、按鍵修飾符
- 第五節 Vue3.x中Dom操作$refs 以及表單( input、checkbox、radio、select、 textarea )結合雙休數據綁定實現在線預約功能
- 第六節 Vue3.x中使用JavaScript表達式 、條件判斷、 計算屬性和watch偵聽
- 第七節 Vue3.x 實現一個完整的toDoList(待辦事項) 以及類似京東App搜索緩存數據功能
- 第八節 Vue3.x中的模塊化以及封裝Storage實現todolist 待辦事項 已經完成的持久化
- 第九節 Vue3.x中的單文件組件 定義組件 注冊組件 以及組件的使用
- 第十節 Vue3.x父組件給子組件傳值、Props、Props驗證、單向數據流
- 第十一節 Vue3.x父組件主動獲取子組件的數據和執行子組件方法 、子組件主動獲取父組件的數據和執行父組件方法
- 第十二節 Vue3.x組件自定義事件 以及mitt 實現非父子組件傳值
- 第十三節 Vue3.x自定義組件上面使用v-mode雙休數據綁定 以及 slots以及 Prop 的Attribute 繼承 、禁用 Attribute 繼承
- 第十四節 Vue3.x中組件的生命周期函數(lifecycle)、 this.$nextTick、動態組件 keep-alive、Vue實現Tab切換
- 第十五節 Vue3.x中全局綁定屬性、使用Axios和fetchJsonp請求真實api接口數據、函數防抖實現百度搜索
- 第十六節 Vue3.x中的Mixin實現組件功能的復用 、全局配置Mixin
- 第十七節 Vue3.x Teleport、使用Teleport自定義一個模態對話框的組件
- 第十八節 Vue3.x Composition API 詳解
- 第十九節 Vue3.x中集成Typescript 使用Typescript
- 第二十節 Vue-Router 詳解
- 第二十節 Vuex教程-Vuex 中的 State Mutation Getters mapGetters Actions Modules