我如何通过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从哪里知道这些对象的来源呢? 如果我像文档说的那样渲染它,我得到了项目和项目的数量,但没有内容。


当前回答

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

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

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

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

其他回答

你可以在一个范围中使用一个索引,然后通过它的索引访问数组:

<ul>
  <li v-for="index in 10" :key="index">
    {{ shoppingItems[index].name }} - {{ shoppingItems[index].price }}
  </li>
</ul>

注意,这是1索引:在第一次迭代中,index是1,在第二次迭代中,index是2,依此类推。

您也可以查看官方文档以获得更多信息。

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

解决方案1:

<p v-for="i in 5" :key="i">{{ i }}</p>

记住,结果是1-5。

解决方案2: 如果你想在数组中显示有限数量的元素。你应该使用JavaScript的slice()方法。

<p v-for="i in usersList.slice(0,5)" :key="i">{{ i }}</p>

尝试v-if在v-for中,因此,例如,如果你想只显示少于3(或任意数量)的项目,那么你可以这样做。

<span v-for="(item, itemIndex) in items" :key="itemIndex">
  <div v-if="itemIndex < 3">
   <p>

   {{ item }}

  </p>
 </div>
</span>

如果你想要循环x次,你可以简单地使用以下命令:

<div v-for="(item, index) in 10" :key="index">{{ item }}</div>