suchen

Heim  >  Fragen und Antworten  >  Hauptteil

javascript - Wie durchläuft Vues Loop V-For zwei Elemente gleichzeitig?

So habe ich es jetzt umgesetzt, aber ich habe immer das Gefühl, dass etwas nicht stimmt

<ul v-for="(item,index) in items" v-if="index%2==0">
  <li>{{items[index].name}}</li>
  <li>{{items[index+1].name}}</li>
</ul>
给我你的怀抱给我你的怀抱2800 Tage vor864

Antworte allen(8)Ich werde antworten

  • 为情所困

    为情所困2017-05-16 13:22:30

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
    </head>
    <body>
        <p id="app">
            <input type="number" v-model.number="count" />
            <ol>
                <li v-for="g in groups">
                    <ol>
                        <li v-for="item in g">{{ item }}</li>
                    </ol>
                </li>
            </ol>
        </p>
    
        <script src="http://cdn.bootcss.com/vue/2.1.6/vue.min.js"></script>
    
        <script>
    
            function GroupByCount(items, count) {
                var len = items.length;
    
                var arr = [];
                var child = [];
    
                for (var i = 0; i < len; i++) {
                    child.push(items[i]);
    
                    if (child.length === count) {
                        arr.push(child);
                        child = [];
                    }
                }
    
                if (child.length > 0) {
                    arr.push(child);
                }
    
                return arr;
            }
    
            new Vue({
                el: '#app',
                data() {
                    return {
                        count: 2,
                        items: []
                    }
                },
                created() {
                    this.items = Array.apply(null, Array(20)).map(function (x, i) { return i; })
                },
                computed: {
                    groups() {
                        return GroupByCount(this.items, this.count)
                    }
                }
            })
        </script>
    </body>
    </html>

    Antwort
    0
  • 过去多啦不再A梦

    过去多啦不再A梦2017-05-16 13:22:30

    <ul v-for="(item,index) in items">    
        <slot v-if="index<items.length&&index%2==0">
          <li >{{items[index].name}}</li>
          <li v-if="index<items.length-1">{{items[index+1].name}}</li>
        </slot>
    </ul>

    Antwort
    0
  • 滿天的星座

    滿天的星座2017-05-16 13:22:30

    <ul v-for="i in (items.length / 2)">
      <li>{{items[(i - 1) * 2].name}}</li>
      <li>{{items[(i - 1) * 2 + 1].name}}</li>
    </ul>

    大概就这么个意思吧,不过有些细节需要你自己稍微再考虑一下,比如说items.length是奇数的时候怎么办

    Antwort
    0
  • 某草草

    某草草2017-05-16 13:22:30

    index是从0开始的

    Antwort
    0
  • 大家讲道理

    大家讲道理2017-05-16 13:22:30

    我怎么感觉你这样写和全部循环没有区别啊。。。

    Antwort
    0
  • PHP中文网

    PHP中文网2017-05-16 13:22:30

    你的需求具体是什么,看你的代码并不能看出什么

    下面是不是你要的东西?
    这一个计算属性,把数组拆分成两个数组放入一个数组

    itemsComputed (){
        let arr = [];
        arr.push(this.items.filter((o,i)=>i%2===0));
        arr.push(this.items.filter((o,i)=>i%2===1));
        return arr;
    }
        <ul>
            <li v-for="item in itemsComputed[0]">
                ...
            </li>
        </ul>
        <ul>
            <li v-for="item in itemsComputed[1]">
                ...
            </li>
        </ul>

    Antwort
    0
  • 高洛峰

    高洛峰2017-05-16 13:22:30

    能直接用模版语法的,就不要做额外计算:

    <template v-for="(item,index) in items">
        <ul v-if="index % 2 == 0">
            <li>{{items[index].name}}</li>
            <li v-if="index < items.length">{{items[index+1].name}}</li>
        </ul>
    </template>

    Antwort
    0
  • PHP中文网

    PHP中文网2017-05-16 13:22:30

    额?这是为了分组显示吗?

    <template>
        <ul v-for="(item,idx) in b">
          <li v-for="i in item">{{i}}</li>
        </ul>
    </template>
    
    <script>
    export default {
      data () {
        return {
          a: [1, 2, 3, 4, 5]
        }
      },
      computed: {
        b () {
          const b = []
          const a = this.a
          for (let i = 0, l = a.length; i < l;) {
            b.push([a[i++], a[i++]])
          }
          return b
        }
      }
    }
    </script>
    

    Antwort
    0
  • StornierenAntwort