当前位置: 移动技术网 > IT编程>脚本编程>vue.js > 解决vue的变量在settimeout内部效果失效的问题

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

2018年09月21日  | 移动技术网IT编程  | 我要评论

太阳能光伏,中国国难日,54sese

解决方法如下:

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

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网