时间:2021-05-26
问题描述,在vue的for循环中使用了指令,然后对数据进行筛选的时候,发现指令没有起作用。
如图前面的图标是根据文件名的后缀名,返回响应图标的,通过指令实现的。然后我们在搜索框中删选以后,数据更新了,但是图标没有更新
分析原因
问题就出在了:key='index'因为vue中for循环是根据key的值的变化来更新vnode的,很显然我们经过筛选如果删选出三条数据,那么index = 0, 1, 2没有变化,所以vnode没有更新
解决办法1:我们设置:key的时候最好使用每条数据的id这样就是唯一的,每次筛选,vnode都会更新。
解决办法2:在指令中设置
// 添加bind设置bind: function (el, binding, vnode) { // bind中的vnode里面的key可以给设置一个随机数,这样每次都会更新虚拟节点。 let num = parseInt(Math.random() * 10) vnode.key = num},inserted: ...总结
以上所述是小编给大家介绍的vue列表数据发生变化指令没有更新问题及解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
这样之前的功夫又白费了。解决这些问题的办法就是:监控页面数据是否发生变化。如果发生变化,提示用户保存。如果数据未发生变化。当我们点击保存时,也不需要提交到数据库
使用Vue的小伙伴都会知道,vue的计算属性。这个是这个样子解释的,当某些依赖值发生变化的时候,其自身的值也会发生变化,与之先关的DOM也会发生变化,通常呢,这
大家都知道,网站改版通常会带来很多问题,比如网站关键词标题描述发生变化,网站版面发生变化,域名发生变化,收录页面造成大量死链接,网站的结构发生变化,不论哪一种,
很多朋友在后台修改了广告代码之后,而前台的广告并没有发生变化,这个原因就是缓存问题了.适合新手的解决方法:如果你修改了广告代码之后,然后我们找到右侧的管理,管理
1、觉得angualr.js的路由是针对于单页面的路由,每次路由发生变化,只是页面的状态发生变化,页面本身没有发生跳转2、express的路由是针对多页面的,也