首页 > 编程 > JavaScript > 正文

解决vue的变量在settimeout内部效果失效的问题

2019-11-19 13:06:37
字体:
来源:转载
供稿:网友

解决方法如下:

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内部效果失效的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表