首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >vue.js -如何将对象数组拆分为多个div列

vue.js -如何将对象数组拆分为多个div列
EN

Stack Overflow用户
提问于 2018-04-26 08:18:55
回答 5查看 9.9K关注 0票数 5

这是我的vue布局:

代码语言:javascript
复制
<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>

目标是:

代码语言:javascript
复制
<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 )中,可以这样做:

代码语言:javascript
复制
{% for article_row in articles | batch(3, '&nbsp;') %}
  <div class="row">
    {% for article in article_row %}
    <div class="span4">{{ article }}</div>
    {% endfor %}
  </div>
{% endfor %}

那么,在vue.js中有这样的方法吗?

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2018-04-26 08:41:16

我将使用helper数组在行中呈现项目组:

代码语言:javascript
复制
<template lang="pug">
  .container
    .row(v-for="(group, i) in articleGroups")
      .col-4(v-for="article in articles.slice(i * itemsPerRow, (i + 1) * itemsPerRow)")
        | {{ article.name }}
</template>

<script>
export default {
  name: 'Articles',
  data() {
    return {
      itemsPerRow: 3,
      articles: [
        { name: 'Article 1' },
        { name: 'Article 2' },
        { name: 'Article 3' },
        { name: 'Article 4' },
        { name: 'Article 5' },
        { name: 'Article 6' },
      ]
    }
  },
  computed: {
    articleGroups () {
      return Array.from(Array(Math.ceil(this.articles.length / this.itemsPerRow)).keys())
    }
  },
}
</script>

演示: https://codesandbox.io/s/rj60o8l5p

票数 10
EN

Stack Overflow用户

发布于 2018-04-26 08:49:02

我会用一个计算的属性把它们分块。如果您有可用的lodash,您可以:

代码语言:javascript
复制
computed: {
  chunked () {
    return _.chunk(this.articles, 3)
  },
},

如果你周围没有房客的话,你可以找到到处乱跑的逻辑。

代码语言:javascript
复制
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
}

然后,你可以:

代码语言:javascript
复制
<div class="row" v-for="chunk in chunked">
  <div class="col-4" v-for="article in chunk">
    {{ article.name }}
  </div>
</div>
票数 10
EN

Stack Overflow用户

发布于 2018-04-26 08:21:55

v-for="(article,i) in articles"v-if="i>=0 && i<3"的结合

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50038129

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档