recherche

Maison  >  Questions et réponses  >  le corps du texte

javascript - Comment la boucle V-For de Vue parcourt-elle 2 éléments à la fois?

C'est ainsi que je l'ai mis en œuvre maintenant, mais j'ai toujours l'impression que quelque chose ne va pas

<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 Il y a quelques jours867

répondre à tous(8)je répondrai

  • 为情所困

    为情所困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>

    répondre
    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>

    répondre
    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>

    C'est probablement ce que cela signifie, mais il y a certains détails auxquels vous devez réfléchir un peu plus, comme par exemple que faire lorsque items.lengthest un nombre impair

    répondre
    0
  • 某草草

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

    index是从0开始的

    répondre
    0
  • 大家讲道理

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

    Pourquoi ai-je l’impression qu’il n’y a aucune différence entre ce que vous écrivez ainsi et toute la boucle ? . .

    répondre
    0
  • PHP中文网

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

    Quels sont vos besoins spécifiques ? Vous ne pouvez rien dire en regardant votre code

    Ce qui suit est-il ce que vous voulez ?
    Il s'agit d'un attribut calculé, divisez le tableau en deux tableaux et placez-les dans un seul tableau

    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>

    répondre
    0
  • 高洛峰

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

    Si vous pouvez utiliser directement la syntaxe du modèle, vous n'avez pas besoin d'effectuer de calculs supplémentaires :

    <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>

    répondre
    0
  • PHP中文网

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

    Euh ? Est-ce pour un affichage groupé ?

    <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>
    

    répondre
    0
  • Annulerrépondre