vue中使用定時器時this指向


箭頭函數中的this指向是固定不變(定義函數時的指向),在vue中指向vue;
普通函數中的this指向是變化的(使用函數時的指向),誰調用的指向誰。
 
箭頭函數:
1 let timerOne = setInterval(() => { 2     console.log(this);// vue
3 }, 1000); 4 let timerTwo = setInteval(function () { 5     console.log(this); // window,因為setInterval()函數是window對象的函數
6 }, 1000);
打印結果:
 
1 let timer = setInterval(() => { 2   this.myFunc(); 3 },1000); 4 myFunc(){ 5   console.log('sunyu is handsome !'); 6 }
不用箭頭函數也可以搞定:
1 myFunc(){ 2   console.log(vm.name);// name為已經在created中聲明的變量
3 }; 4 let  vm = this; 5 let timer = setInteval(function () { 6        myFunc(); 7 }, 1000) ;

 

最后溫馨提示不要忘了清除定時器哦!
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM