最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:懂视网 责编:小采 时间:2020-11-27 22:09:04
文档

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

解决vue的变量在settimeout内部效果失效的问题:解决方法如下: 1、定义一个self暂存this 2、再改变变量的值,则生效啦 var self=this; this.toastrVal = inVal; this.loadState = true; this.noBg = bgState; setTimeout(function () { self.loadState =
推荐度:
导读解决vue的变量在settimeout内部效果失效的问题:解决方法如下: 1、定义一个self暂存this 2、再改变变量的值,则生效啦 var self=this; this.toastrVal = inVal; this.loadState = true; this.noBg = bgState; setTimeout(function () { self.loadState =

解决方法如下:

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

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

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

解决vue的变量在settimeout内部效果失效的问题:解决方法如下: 1、定义一个self暂存this 2、再改变变量的值,则生效啦 var self=this; this.toastrVal = inVal; this.loadState = true; this.noBg = bgState; setTimeout(function () { self.loadState =
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top