javascript - vue.js - 如何将对象数组拆分为多个 div 列
问题描述
这是我的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>
在像 Flask 和 Jinja 这样的基于 Python 的微框架中,可以这样做:
{% 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 中像上面那样做呢?
解决方案
我会使用计算属性将它们分块。如果你lodash
有空,你可以这样做:
computed: {
chunked () {
return _.chunk(this.articles, 3)
},
},
如果您周围没有 lodash,您可以在各处找到分块的逻辑。
function chunk (arr, len) {
const chunks = []
const i = 0
const n = arr.length
while (i < n) {
chunks.push(arr.slice(i, i += len))
}
return chunks
}
然后,你可以这样做:
<div class="row" v-for="chunk in chunked">
<div class="col-4" v-for="article in chunk">
{{ article.name }}
</div>
</div>
推荐阅读
- javascript - PDFTron WebViewer - 有没有办法用评论框替换回复框?
- javascript - 如何通过 Javascript 中的正则表达式获取多个电子邮件地址
- javascript - 在刷新页面时记住类名
- javascript - 找到满足某些条件的数组的子集
- xml - 在 xml 元素中导入命名空间
- excel - 在此示例中如何避免 VBA 中的选择/活动语句?
- java - Spring Boot 将 OAuth2 和 HttpBasic Login 与自定义表单相结合
- c - 启用内核 TLS 选项时,setsockopt 失败
- google-cloud-platform - 查找与存储桶关联的服务帐户的权限
- c++ - C++ 访问基于 1 而不是 0 的数组,通过在编译时移位