vue 解决异步数据更新问题
网络编程 2021-07-04 15:02www.168986.cn编程入门
今天长沙网络推广就为大家分享一篇vue 解决异步数据更新问题,具有很好的参考价值,希望对大家有所帮助。一起跟随长沙网络推广过来看看吧
问题
记录一下出现的问题, 数据翻倍
这是复现问题的代码
data() { return { space: "", allresult: [] }; }, methods: { getmessage() { this.allresult = []; axios .get( "https://gist.githubusercontent./xiaolannuoyi/9b0defe4959e71fa97e60964f82ba4/raw/4be939123d488cee7ecefc055fb5ecb2ed8d5c8d/test" ) .then(data => { console.log(data); let result = data.data; for (let i = 0; i < result.length; i++) { //原因在于这里的this.Allresult this.allresult.push({ id: result[i].id, name: result[i].name, age: result[i].age }); } console.log('此时的this.allresult',this.allresult); }); } }, watch: { space() { console.log("watch"); this.getmessage(); } }, mounted() { this.space = "123"; console.log("mounted"); this.getmessage(); }
结果
此时你可以看到第二次的数据时 是 第一次的 2倍
原因
mounted 和 watch 都执行 getmessage 方法,虽然方法之前 对数据进行了清空,但是 异步请求执行的慢,
所以两次调用getmessage相当于 this.allresult = []; this.allresult = []; axios...;axios....: 这个顺序
所以才会出现上述现象
解决
1.修改this.allresult = []的位置
2.新建一个临时空数组
以上这篇vue 解决异步数据更新问题就是长沙网络推广分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。
上一篇:简单使用webpack打包文件的实现
下一篇:VUE实现强制渲染,强制更新
编程语言
- 机械手焊接机器人编程 机械手焊接设备编程
- vb数据库编程实例,vb做数据库
- tiobe世界编程语言排行榜,全球编程语言排行
- 成都java编程培训 成都it编程培训中心
- 编程基础培训,编程基础知识培训
- flash游戏编程基础教程,flash游戏开发教程
- 不会英语能学编程吗 不会英语可以学程序员吗
- 爱心代码编程C语言 爱心代码编程c语言公式
- c语言编程学习入门 c语言编程快速入门
- 西门子plc编程培训 西门子plc编程培训班
- 哪里可以学编程 台州哪里可以学编程
- 少儿编程哪个好 少儿编程哪个品牌好
- 编程是什么意思,图形编程是什么意思
- c语言编程软件下载,c语言编程软件在哪下载
- java编程软件下载,java编程下载手机版
- ug编程培训学校,ug编程培训教程