**永遠不要把?`v-if`?和?`v-for`?同時用在同一個元素上。**
~~~
//好例子
<ul>
<li
v-for="user in activeUsers"
:key="user.id"
>
{{ user.name }}
</li>
~~~
~~~
</ul>
<ul v-if="shouldShowUsers">
<li
v-for="user in users"
:key="user.id"
>
{{ user.name }}
</li>
</ul>
~~~
一般我們在兩種常見的情況下會傾向于這樣做:
* 為了過濾一個列表中的項目 (比如?`v-for="user in users" v-if="user.isActive"`)。在這種情形下,請將?`users`?替換為一個計算屬性 (比如?`activeUsers`),讓其返回過濾后的列表。
* 為了避免渲染本應該被隱藏的列表 (比如?`v-for="user in users" v-if="shouldShowUsers"`)。這種情形下,請將?`v-if`?移動至容器元素上 (比如?`ul`,?`ol`)。
#### 詳解
當 Vue 處理指令時,`v-for`?比?`v-if`?具有更高的優先級,所以這個模板:
~~~
<ul>
<li
v-for="user in users"
v-if="user.isActive"
:key="user.id"
>
{{ user.name }}
</li>
</ul>
~~~
將會經過如下運算:
~~~
this.users.map(function (user) {
if (user.isActive) {
return user.name
}
})
~~~
因此哪怕我們只渲染出一小部分用戶的元素,也得在每次重渲染的時候遍歷整個列表,不論活躍用戶是否發生了變化。
通過將其更換為在如下的一個計算屬性上遍歷:
~~~
computed: {
activeUsers: function () {
return this.users.filter(function (user) {
return user.isActive
})
}
}
~~~
~~~
<ul>
<li
v-for="user in activeUsers"
:key="user.id"
>
{{ user.name }}
</li>
</ul>
~~~
我們將會獲得如下好處:
* 過濾后的列表*只*會在?`users`?數組發生相關變化時才被重新運算,過濾更高效。
* 使用?`v-for="user in activeUsers"`?之后,我們在渲染的時候*只*遍歷活躍用戶,渲染更高效。
* 解藕渲染層的邏輯,可維護性 (對邏輯的更改和擴展) 更強。
為了獲得同樣的好處,我們也可以把:
~~~
<ul>
<li
v-for="user in users"
v-if="shouldShowUsers"
:key="user.id"
>
{{ user.name }}
</li>
</ul>
~~~
更新為:
~~~
<ul v-if="shouldShowUsers">
<li
v-for="user in users"
:key="user.id"
>
{{ user.name }}
</li>
</ul>
~~~
通過將?`v-if`?移動到容器元素,我們不會再對列表中的*每個*用戶檢查?`shouldShowUsers`。取而代之的是,我們只檢查它一次,且不會在?`shouldShowUsers`?為否的時候運算?`v-for`。
- Vue開發規范
- 基于模塊開發
- 組件
- 組件命名規則
- 基礎組件名
- 單例組件名
- 緊密耦合的組件名
- 組件名中的單詞順序
- 組件文件夾命名規則
- method方法
- methods方法命名規則
- 組件結構化
- 組件事件命名規則
- v-for與v-if
- 為 v-for 設置鍵值
- 避免 v-if 和 v-for 用在一起
- Prop
- Prop命名規則
- Prop定義
- 避免 this.$parent
- 謹慎使用 this.$refs
- 隱性的父子組件通信
- 元素
- 元素特性的順序
- 多個特性的元素擺放規則
- 單文件組件的頂級元素的順序
- 簡化代碼
- 模板中簡單的表達式
- 簡單的計算屬性
- 指令縮寫
- 文件引用路徑
- 其他注意
- 組件數據
- 將 this 賦值給 component 變量
- 對組件文件進行代碼校驗
- 盡可能使用 mixins
- 非 Flux 的全局狀態管理
- 只在需要時創建組件
- HTML開發規范
- HTML語法
- HTML5 doctype
- 語言屬性
- IE 兼容模式
- 字符編碼
- 引入 CSS 和 JavaScript 文件
- 實用為王
- 屬性順序
- 布爾(boolean)型屬性
- 減少標簽的數量
- JavaScript 生成的標簽
- CSS開發規范
- CSS語法
- 聲明順序
- 不要使用 @import
- 媒體查詢(Media query)的位置
- 帶前綴的屬性
- 單行規則聲明
- 簡寫形式的屬性聲明
- Less 和 Sass 中的嵌套
- Less 和 Sass 中的操作符
- 注釋
- class 命名
- 選擇器
- 代碼組織