当在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就会访问到这个变量,就会得到当前对象。

Logo

前往低代码交流专区

更多推荐