this value was evaluated upon first expanding节点数组无法遍历问题VUE

遇到问题

需要在页面渲染完成之后获取文档标题的scrollTop用来监听计算活动菜单项。在mounted中执行获取

const elements = document.querySelectorAll('className');
console.log(elements);
elements.map(...) 

发现提示错误.map is not function, 通过打印发现数组发现 this value was evaluated upon first expanding, that maybe change since then 。然后发现不论使用Array.from或者[...elements] 或者 JSON.parse(JSON.stringfify(elements))都无法获取到里面的数据,但是打印台是可以看见的。
文档内容通过v-html渲染的

分析原因

上面错误提示翻译过来就是,当前数值是在第一次展开的时候计算得出的,这个值是随时变化的。所以感觉应该是执行顺序问题

解决方案

最后通过将执行顺序mounted挪到updated里面就可以了,如果还不行在执行前加上this.$nextTick

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值