• 技术文章 >web前端 >html教程

    详解Vue列表渲染

    php中世界最好的语言php中世界最好的语言2018-03-08 17:29:45原创1044
    这次给大家带来详解Vue列表渲染,详解Vue列表渲染的注意事项有哪些,下面就是实战案例,一起来看一下。

    变异方法 (mutation method),顾名思义,会改变被这些方法调用的原始数组。相比之下,也有非变异 (non-mutating method) 方法,例如:filter(), concat() 和 slice() 。这些不会改变原始数组,但总是返回一个新数组。当使用非变异方法时,可以用新数组替换旧数组:

    example1.items = example1.items.filter(function (item) {  return item.message.match(/Foo/)})
    <div id="example">
      <div>
        <button @click="concat()">concat</button>
        <button @click="slice()">slice</button>
        <button @click="filter()">filter</button>
      </div>
      <ul>
        <li v-for="item in items">
          {{item.list}}
        </li>
      
      </ul>
    </div>
    <script>
      var example = new Vue({
        el:"#example",
        data:{
          items:[
            {list:5},
            {list:6},
            {list:7}
          
          ],
          addValue:{list:10}
        },
        methods:{
          concat(){
         this.items= this.items.concat(this.addValue)
          },
          slice(){
          this.items = this.items.slice(1)
          },
          filter(){
          this.items = this.items.filter(function(item,index,arr) {
              return (index > 0)
            })
          }
        
        }
      })

    以上操作并不会导致Vue丢弃现有DOM并重新渲染整个列表。Vue实现了一些智能启发式方法来最大化DOM元素重用,所以用一个含有相同元素的数组去替换原来的数组是非常高效的操作

    注意事项

    由于 JavaScript 的限制,Vue 不能检测以下变动的数组:

    当你利用索引直接设置一个项时,例如:

    vm.items[indexOfItem] = newValue

    当你修改数组的长度时,例如:

    vm.items.length = newLength

    为了解决第一类问题,以下两种方式都可以实现和 vm.items[indexOfItem] = newValue 相同的效果,同时也将触发状态更新

    // Vue.set
    Vue.set(example1.items, indexOfItem, newValue)
    // Array.prototype.splice
    example1.items.splice(indexOfItem, 1, newValue)

    为了解决第二类问题,你可以使用 splice:

    example1.items.splice(newLength)

    相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

    相关阅读:

    在HTML中如何用<a>标签编写个人收藏夹

    HTML用img标签做图

    HTML里的常见问题一

    以上就是详解Vue列表渲染的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:渲染 列表 详解
    上一篇:用<h1>和段落<p> 写一个三毛语录 下一篇:用React完成一个图片轮播组件
    大前端线上培训班

    相关文章推荐

    • html怎么设置元素不可见• html怎么设置表格标题• html怎么去掉input边框• html图片的透明度怎么设置• html div怎么设置大小

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网