在Vue中,為了方便快捷地對同一種類型的元素進行操作,我們可以使用循環來遍歷數據,根據數據中的每一項生成相應數量的元素。如果要操作的元素需要再循環內再進行循環,Vue的嵌套循環就能派上用場了。
首先我們來看一下最簡單的循環:
<div v-for="item in items" :key="item.id">
{{ item.name }}
</div>
這段代碼會遍歷`items`數組中的每一項,并生成相應數量的`div`元素,每個元素的內容都是當前項的`name`屬性。`v-for`指令后面的`item`變量代表每一項的值,`in`之后的`items`則是被遍歷的數組名。
如果相同的元素需要再進行循環,那么我們可以在循環內再加一個`v-for`指令,例如:
<div v-for="item in items" :key="item.id">
<p>{{ item.name }}</p>
<ul>
<li v-for="subItem in item.subItems" :key="subItem.id">
{{ subItem.name }}
</li>
</ul>
</div>
這里的`items`數組中每一項都有一個名為`subItems`的子數組。循環每一個`item`時,都會生成一個`p`元素來顯示當前`item`的`name`屬性,同時也會生成一個`ul`元素,內部再進行一次循環,遍歷`item.subItems`數組中的每一項。`v-for`指令后面的`subItem`變量指的是當前子項的值。
如果循環的層數更深,可以按照上面的方式在內層循環中再加一個`v-for`來處理。需要注意的是,循環的層數越深,渲染的時間和內存占用也會多,所以應盡量避免過于復雜的嵌套循環。