首頁 > web前端 > js教程 > vuejs中列表渲染的詳細介紹

vuejs中列表渲染的詳細介紹

不言
發布: 2018-08-14 16:47:38
原創
2849 人瀏覽過

這篇文章帶給大家的內容是關於vuejs中清單渲染的詳細介紹,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

用v-for把一個陣列對應到一組元素

我們用v-for指令根據一組陣列的選項清單進行渲染。 v-for指令需要使用item in items形式的特殊語法,items是來源資料數組且item是數組元素迭代的別名。

<ul id="example-1">
<li v-for="item in items">
{{ item.message }}
</li>
</ul>
var example1 = new Vue({
el: &#39;#example-1&#39;,
data: {
items: [
{ message: &#39;Foo&#39; },
{ message: &#39;Bar&#39; }
]
}
})
登入後複製

在v-for快中,我們擁有對父作用域屬性的完全存取權。 v-for也支援一個可選的第二個參數為目前項目的索引。

<ul id="example-2">
<li v-for="(item, index) in items">
{{ parentMessage }} - {{ index }} - {{ item.message }}
</li>
</ul>
var example2 = new Vue({
el: &#39;#example-2&#39;,
data: {
parentMessage: &#39;Parent&#39;,
items: [
{ message: &#39;Foo&#39; },
{ message: &#39;Bar&#39; }
]
}
})
登入後複製

你也可以用of取代in當分隔符,因為他是最接近javascript迭代器的語法

<p v-for="item of items"></p>
登入後複製

一個物件的v-for

你也可以用v-for透過一個物件的屬性來迭代。

<ul id="v-for-object" class="demo">
<li v-for="value in object">
{{ value }}
</li>
</ul>
new Vue({
el: &#39;#v-for-object&#39;,
data: {
object: {
firstName: &#39;John&#39;,
lastName: &#39;Doe&#39;,
age: 30
}
}
})
登入後複製

你也可以提供第二個的參數為鍵名

<p v-for="(value, key) in object">
{{ key }}: {{ value }}
</p>
登入後複製

第三個參數為索引:

#
<p v-for="(value, key, index) in object">
{{ index }}. {{ key }}: {{ value }}
</p>
登入後複製

在遍歷物件時,是按Object.key()的結果遍歷,但是不能保證他的結果在不同的javascript引擎下是一致的,

key

當vue.js用v-for正在更新已渲染過的元素清單時,他預設用「就地複用」策略。如果資料項的順序被改變。 vue將不會移動dom元素來匹配資料項的順序,而是簡單地複用此處每個元素,並確保他在特定索引下顯示被渲染過的每個元素。這個類似vue1.x的track-by="$index"。

這個預設的模式是高效率的,但只適用於不依賴子元件狀態或暫存dom狀態(例如:表單輸入值)的清單渲染輸出。

為了給vue一個提示,以便它能追蹤每個節點的身份,從而重複使用和重新排序現有的元素,你需要為每一項提供一個唯一的key屬性。理想的key值是每項都有的且唯一的id,這個特殊的屬性相當於vue1.x的track-by,但它的工作方式類似於一個屬性,所以你需要用v-bind來綁定動態值。

<p v-for="item in items" :key="item.id">
<!-- 内容 -->
</p>
登入後複製

建議盡可能在使用v-for時提供key,除非遍歷輸出的dom內容非常簡單,或者是可以依賴預設行為以取得效能上的提升。

因為他是vue辨識節點的一個通用機制,key並不是與v-for特別關聯,key還具有其他用途,

陣列更新偵測

#編譯方法

vue包含一直觀察陣列的編譯方法,所以他們也會觸發視圖更新。

* push()———進數組

#* pop()————出數組

* shift()————

* unshift()

* splice()————分割陣列

* sort() ————對陣列排序

* reverse()————翻轉陣列

#取代陣列

變異方法,會改變這些方法呼叫的原始陣列。相比之下,也有非變異方法。例如:filter(), concat() 和 slice() 。

這些不會改變原始數組,但總是會傳回一個新數組 。當時用非變異方法時,可以用新數組替換就數組

#
example1.items = example1.items.filter(function (item) {
return item.message.match(/Foo/)
})
登入後複製

你可能認為這將導致vue丟棄現有dom並重新渲染整個清單。幸運的是,事實並非如此,vue為了使得dom元素得到最大範圍的重用而實現了一些智能的、啟發式的方法,所以用一個含有相同元素的數組去替換原來的數組是非常高效的操作。

注意事項

由於javascript的限制,vue無法偵測以下變動的陣列

1、當你利用索引直接設定一個項目時,例如: vm.items[ indexOfItem] = newValue

2、當你修改陣列的長度時,例如: vm.items.length = newLength

var vm = new Vue({
data: {
items: [&#39;a&#39;, &#39;b&#39;, &#39;c&#39;]
}
})
vm.items[1] = &#39;x&#39; // 不是响应性的
vm.items.length = 2 // 不是响应性的
登入後複製

為了解決第一類問題,以下兩種方式都可以實作和vm.items[indexOfItem] = newValue相同的效果,同時也會觸發狀態更新

// Vue.set
Vue.set(vm.items, indexOfItem, newValue)
// Array.prototype.splice
vm.items.splice(indexOfItem, 1, newValue)
登入後複製

你也可以使用vm.$set实例方法,该方法是全局方法vue.set的一个别名

vm.$set(vm.items, indexOfItem, newValue)
登入後複製

为了解决第二类问题,你可以使用splice

vm.items.splice(newLength)
登入後複製

splice()方法向/从数组添加/删除项目,然后返回被删除的项目

arrayObject.splice(index,howmany,item1,.....,itemX)
登入後複製

index

必需。整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置。

howmany

必需。要删除的项目数量。如果设置为 0,则不会删除项目。

item1, ..., itemX

可选。向数组添加的新项目。

对象更改检测注意事项

还是由于javascript的限制,vue不能检测对象属性的添加或删除

var vm = new Vue({
data: {
a: 1
}
})
// `vm.a` 现在是响应式的
 
vm.b = 2
// `vm.b` 不是响应式
登入後複製

对于已经创建的实例,vue不能动态添加跟级别的响应式属性。但是,可以使用 Vue.set(object, key, value)方法向嵌套对象添加响应式属性。

var vm = new Vue({
data: {
userProfile: {
name: &#39;Anika&#39;
}
}
})
登入後複製

你可以添加一个age属性到嵌套的userProfile对象:

Vue.set(vm.userProfile, &#39;age&#39;, 27)
登入後複製

你还可以使用vm.$set实例方法,他只是全局vue.set的别名

vm.$set(vm.userProfile, &#39;age&#39;, 27)
登入後複製

有事你可能需要为已有对象赋予多个新属性,比如使用 Object.assign() 或 _.extend()。在这种情况下,你应该用两个对象的属性创建一个新的对象。所以,如果你想添加新的响应式属性,不要像这样:

Object.assign(vm.userProfile, {
age: 27,
favoriteColor: &#39;Vue Green&#39;
})
你应该这样:
vm.userProfile = Object.assign({}, vm.userProfile, {
age: 27,
favoriteColor: &#39;Vue Green&#39;
})
登入後複製

显示过滤/排序结果

有事,我们想要显示一个数组的过滤或排序副本,而不实际改变 或重置原始数据。在这种情况下,可以创建返回过滤或排序 数组的计算属性。

<li v-for="n in evenNumbers">{{ n }}</li>
data: {
  numbers: [ 1, 2, 3, 4, 5 ]
},
computed: {
  evenNumbers: function () {
    return this.numbers.filter(function (number) {
      return number % 2 === 0
    })
  }
}
登入後複製

在计算属性不使用的情况下,(例如,在嵌套v-for循环中)你可以使用method方法。

data: {
numbers: [ 1, 2, 3, 4, 5 ]
},
methods: {
even: function (numbers) {
return numbers.filter(function (number) {
return number % 2 === 0
})
}
}
登入後複製

一段取值范围的v-for

v-for也可以取整数。在这种情况下 ,它将重复多刺激模板。

<p>
<span v-for="n in 10">{{ n }} </span>
</p>
登入後複製

v-for on a