近期开发了一个新功能,就是上传图片,并支持删除,于是乎写了一个组件。上传是没有问题的,但是删除的时候老是出问题,问题是删除的时候,例如总共上传了4张图片,我删除了第二张,就剩下了三张,但是现在的第二张和第三张图片是一样的,这是什么情况?经过分析之后,知道了是因为缓存的原因。使用v-for的时候设置key值得时候,我用的是index,导致存在缓存的情况,这个和vue中的diff算法有关。于是,我就给每一项设置一个独一无二的索引值,就是给每一项加一个时间戳new Date().getTime()作为索引值,这样的话就没有缓存的情况了,完美地解决了这个问题,补充:独一无二的索引值用symbol类型的值会更好一点。后面会总结一下vue中的diff算法。
vue中上传图片使用v-for所带的key值的缓存问题
最新推荐文章于 2023-01-06 17:10:02 发布