vue+iview 当v-for不渲染问题 因为遇到Modal组件

1 篇文章 0 订阅
<template lang="pug">
    div#parent
      Button(@click="data.push(Math.random())") 添加
      span data:{{data}}
      div(v-for="indx in data") {{indx}}
      Modal
</template>
<script>
export default {
  data() {
    return {
      data: []
    };
  }
};
</script>

运行如上代码,当点击添加的时候data这个数组的确在不停的增加数据,但是那个v-for却只增加了一行 就再也不动了。明明应该时data钟有多少就应该渲染多少行

解决办法

  1. 在v-for外面套一个div
  2. 不要把Modal直接放在v-for后面 可以提前去

原因分析

  1. 通过分析 vue的 updateChildren函数 当数据变化的时候 这个函数会进行新旧虚拟节点vNode进行 对比。并且如果有新的vNode的时候会执行 如下这个vue的函数来进行真实dom的更新

  function insert (parent, elm, ref$$1) {
    if (isDef(parent)) {
      if (isDef(ref$$1)) {
        if (ref$$1.parentNode === parent) { // 注意这里-
          nodeOps.insertBefore(parent, elm, ref$$1);
        }
      } else {
        nodeOps.appendChild(parent, elm);
      }
    }
  }

看到代码后面注释的这一行 。
ref

1Modaldom>ref
1.parentNode === parent 如果Modal的附元素和v-for这个的父元素相等才会做插入操作。但是Modal这个元素又会被移动到body下面去,所以导致了界面不更新的问题。

注意

  1. 这个例子代码刚开始出来会有一个undefined 请参考这个文章
    http://blog.csdn.net/tearsknow/article/details/78411672
  2. 为什么点添加时还能渲染出一个,请研究vue中的updateChildren函数
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值