我如何通过v-for X(例如10)次重复一个循环?

<!-- want to repeat this (e.g.) 10 times -->

<ul>
  <li v-for="item in shoppingItems">
    {{ item.name }} - {{ item.price }}
  </li>
</ul>

文档显示:

<ul>
  <li v-for="item in 10">{{ item }}</li>
</ul>

<!-- or -->

<li v-for="n in 10">{{ n }} </li>

<!-- this doesn't work -->

<li v-for="item in 10">{{ item.price }}</li>

但是vue从哪里知道这些对象的来源呢? 如果我像文档说的那样渲染它,我得到了项目和项目的数量,但没有内容。


当前回答

对于range中的v-for也是一样:

<li v-for="n in 20 " :key="n">{{n}}</li>

其他回答

你可以使用原生JS slice方法:

<div v-for="item in shoppingItems.slice(0,10)">

slice()方法将数组中选定的元素作为一个新的数组对象返回。

根据迁移指南中的提示:https://v2.vuejs.org/v2/guide/migration.html#Replacing-the-limitBy-Filter

我在Dov Benjamin的帮助下解决了这个问题

<ul>
  <li v-for="(n,index) in 2">{{ n }}, {{ index }}</li>
</ul>

注意,在这种情况下,n是1索引,index是0索引。

另一种方法,对于两个V1。X和2。vue.js的X

Vue 1:

<p v-for="item in items | limitBy 10">{{ item }}</p>

Vue2:

// Via slice method in computed prop

<p v-for="item in filteredItems">{{ item }}</p>

computed: {
   filteredItems: function () {
     return this.items.slice(0, 10)
     }
  }
<ul v-for="(item, index) in items.slice(0,10)" :key="item.index">
<li>
 {{item.name}}-{{item.price}}
</li>
</ul>

在2.2.0+中,当对组件使用v-for时,现在需要一个键。

<div v-for="item in items" :key="item.id">

这对我有用。

<li v-for="(index,key) in data.slice(0,5)" :key="key">{{ index.title }}</li>