解决vue的变量在settimeout内部效果失效的问题
发布时间:2020-12-17 02:11:46 所属栏目:百科 来源:网络整理
导读:解决方法如下: 1、定义一个self暂存this 2、再改变变量的值,则生效啦 拓展知识:解决vue在setTimeout内修改this失效的问题 当在vue中使用定时器来修改一个变量值的时候,发现没有效果,这是由于setTimeout函数调用的代码运行在与所在函数完全分离的执行环
解决方法如下:1、定义一个self暂存this 2、再改变变量的值,则生效啦 拓展知识:解决vue在setTimeout内修改this失效的问题 当在vue中使用定时器来修改一个变量值的时候,发现没有效果,这是由于setTimeout函数调用的代码运行在与所在函数完全分离的执行环境上,这会使得this指向的是window对象。 要想setTimeout指向正确的值,可以使用如下方法: 1、使用箭头函数 {
this.bottom = 0;
this.left = 0;
},500);
}
}
}
此时函数的this指向的是定义它的时候的对象,也就是this指向了data内中对应的变量。 2、将当前对象的this保存为一个变量方法中将this存在一个对象中,此时执行setTimeout函数时,setTimeout函数内的that就会访问到这个变量,就会得到当前对象。 以上这篇解决vue的变量在settimeout内部效果失效的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |