cari

Rumah  >  Soal Jawab  >  teks badan

javascript - Bagaimanakah vue menentukan sama ada nilai tertentu dalam v-for diubah?

Lepaskan kod dahulu, kemudian tampal terus untuk melihat kesannya

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title></title>
    <script src="//cdn.bootcss.com/vue/2.3.4/vue.min.js"></script>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        .bg {
            width: 300px;
            height: 400px;
            position: absolute;
            top: 50px;
            left: 100px;
            border: 1px solid #ccc;
        }

        .bg ul li {
            margin-bottom: 50px;
        }
    </style>
</head>
<body>
<p>
<p class="bg">
    <ul>
        <li v-for="item of list" :key="item.id">
            <h2>{{ item.name }}</h2>
            <span v-show="false">我出现了</span>
        </li>
    </ul>
</p>
<script>
const app = new Vue({
    el: '.bg',
    data () {
        return {
            list: [
                {
                    id: 0,
                    name: '李四',
                    number: 0
                },
                {
                    id: 1,
                    name: '张三',
                    number: 0
                },
                {
                    id: 2,
                    name: '王五',
                    number: 0
                },
            ]
        }
    }
})
</script>
</p>
</body>
</html>

Saya ingin memantau sama ada nombor di bawah senarai telah berubah atau lebih besar daripada nombor semasa.
Jika nombor bertukar, span di bawah h2 akan muncul. Kemudian ia hilang dalam 1 saat.

Tetapi saya tidak tahu bagaimana untuk melakukannya. (Nota: Span mana yang muncul apabila nombor berubah. Tidak semuanya muncul.)

过去多啦不再A梦过去多啦不再A梦2765 hari yang lalu973

membalas semua(2)saya akan balas

  • 高洛峰

    高洛峰2017-06-30 10:00:49

    Bagus, anda harus menggunakan jam tangan

    Sepatutnya diasingkan dan digunakan saya rasa kaedah penulisan Vue yang asal sepatutnya begini:

    Vue.component('list-view', {
      props: ['item'],
      data() {
        return {
          is_show: false
        }
      },
      watch: {
        'item.number': function(newN, oldN) {
          this.is_show = newN > oldN;
        },
        is_show: function(newStatus) {
          if (newStatus) {
            setTimeout(() => this.is_show = false, 1000);
          }
        }
      },
      template: `
          <li>
            <h2 v-text="item.name"></h2>
          <span v-show="is_show">我出现了</span>
        </li>`
    });
    
    const app = new Vue({
      el: '.bg',
      data() {
        return {
          list: [{
            id: 0,
            name: '李四',
            number: 0
          }, {
            id: 1,
            name: '张三',
            number: 0
          }, {
            id: 2,
            name: '王五',
            number: 0
          }, ]
        }
      },
      mounted() {
        //测试用的
        setTimeout(() => {
          this.$set(this.list[0], 'number', 1);
        }, 1000);
        setTimeout(() => {
          this.$set(this.list[1], 'number', 1);
        }, 2000);
        setTimeout(() => {
          this.$set(this.list[2], 'number', 1);
        }, 3000);
      }
    });
    <p>
      <p class="bg">
        <ul>
          <list-view v-for="item in list" :item="item" :key="item.id">
          </list-view>
        </ul>
      </p>
    </p>

    Anda boleh pergi ke https://jsfiddle.net/1rb586dr/2/ untuk mengalaminya

    balas
    0
  • 曾经蜡笔没有小新

    曾经蜡笔没有小新2017-06-30 10:00:49

    Anda boleh menggunakan watch()properties

    dokumentasi api: vue-vatch

    Semoga ia dapat membantu anda, jika anda masih belum faham@我

    balas
    0
  • Batalbalas