以下是我的vue布局:
<template lang="pug">
.row
.col-4(v-for="article in articles") // need to render 1-3 items here
| {{ article.name }}
.row
.col-4(v-for="article in articles") // need to render 4-6 items here
| {{ article.name }}
</template>
<script>
export default {
name: 'Articles',
data() {
return {
articles: [
{ name: 'Article 1' },
{ name: 'Article 2' },
{ name: 'Article 3' },
{ name: 'Article 4' },
{ name: 'Article 5' },
{ name: 'Article 6' },
]
}
},
}
</script>
目标是:
<div class="row">
<div class="col-4">article[0].name</div>
<div class="col-4">article[1].name</div>
<div class="col-4">article[2].name</div>
</div>
<div class="row">
<div class="col-4">article[3].name</div>
<div class="col-4">article[4].name</div>
<div class="col-4">article[5].name</div>
</div>
在基于Python的微框架中,如Flask和Jinja,可以这样做:
{% for article_row in articles | batch(3, ' ') %}
<div class="row">
{% for article in article_row %}
<div class="span4">{{ article }}</div>
{% endfor %}
</div>
{% endfor %}
那么,在vue.js中是否有类似上述的方法呢?
6条答案
按热度按时间cpjpxq1n1#
我将使用helper groups array来呈现行中的文章组:
Demo:https://codesandbox.io/s/rj60o8l5p
xtfmy6hx2#
我会使用计算属性来将它们分成块。如果您有
lodash
可用,您可以:如果你没有lodash的话,你可以找到块的逻辑,这将工作。
然后,您可以执行以下操作:
bvn4nwqk3#
v-for="(article,i) in articles"
和v-if="i>=0 && i<3"
的组合c3frrgcw4#
使用.reduce你可以将数组分解为X组。
gwbalxhn5#
在代码中使用lodash.chunk()函数的简单方法是:
请参考此处以获得lodash.chunk()函数的详细解释:https://dustinpfister.github.io/2017/09/13/lodash-chunk/
eyh26e7m6#
对于Vue 3,你可以这样做:
1.安装lodash将数组/对象拆分为块:
npm i lodash
1.导入lodash并在vue组件中使用如下: