解决vue的变量在settimeout内部效果失效的问题
程序员文章站
2023-08-17 13:56:51
解决方法如下:
1、定义一个self暂存this
2、再改变变量的值,则生效啦
var self=this;
this.toastrval =...
解决方法如下:
1、定义一个self暂存this
2、再改变变量的值,则生效啦
var self=this; this.toastrval = inval; this.loadstate = true; this.nobg = bgstate; settimeout(function () { self.loadstate = false; }, 3000)
拓展知识:解决vue在settimeout内修改this失效的问题
当在vue中使用定时器来修改一个变量值的时候,发现没有效果,这是由于settimeout函数调用的代码运行在与所在函数完全分离的执行环境上,这会使得this指向的是window对象。
要想settimeout指向正确的值,可以使用如下方法:
1、使用箭头函数
export default { data () { return { left: -9999, bottom: -9999 } }, methods: { cancelmask: function () { settimeout(() => { this.bottom = 0; this.left = 0; }, 500); } } }
此时函数的this指向的是定义它的时候的对象,也就是this指向了data内中对应的变量。
2、将当前对象的this保存为一个变量
export default { data () { return { left: -9999, bottom: -9999 } }, methods: { cancelmask: function () { var that = this; settimeout(function () { that.bottom = 0; that.left = 0; }, 500); } } }
方法中将this存在一个对象中,此时执行settimeout函数时,settimeout函数内的that就会访问到这个变量,就会得到当前对象。
以上这篇解决vue的变量在settimeout内部效果失效的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
上一篇: 小程序实现多选框功能
下一篇: 微信小程序实现单选功能