問題一:我在一個構(gòu)造函數(shù)里寫了setTime()方法和moveSnake方法,在setTime()里面用setInterval調(diào)用moveSnake方法,此時為什么this指向的是window?
問題二: 我在setTime()里面用setInterval(this.moveSnake.call(Snake),500);為什么返回的是而不是,我依然不能console.log(this.snakeArr)。
但是換了這種
(function(theThis){
var that = theThis;
that.timer = setTimeout(function() {
that.moveSnake();
}, 500);
})(this);
就能讓this指到Snake這個構(gòu)造函數(shù)呢?
那為什么我直接把this當(dāng)成參數(shù)傳給setTimeout不行呢:
var timeTest = setTimeout(function(this) {
this.moveSnake();
},500);
這個樣子就是Unexpected token this了
以下是這一部分的代碼,其他不相關(guān)的沒有貼出:
function Snake(id, score, speed, x, y){
this.id = document.getElementById(id);
this.ctx = this.id.getContext("2d");
this.cellWidth = 10; //每個格子的大小
this.score = document.getElementById(score);
this.speed = document.getElementById(speed);
this.x = x;
this.y = y;
// 畫canvas大小
this.id.width = this.x * this.cellWidth;
console.log(this.id.width);
this.id.height = this.y * this.cellWidth;
this.id.style.border = "1px solid black";
this.setDirection();
}
Snake.prototype = {
init: function() {
this.snakeArr = [[1,parseInt(this.y/2)],[2,parseInt(this.y/2)]]; //蛇身長度。初始化時只有兩個長度,每一個點(diǎn)存了[x,y]兩個坐標(biāo),parseInt(this.y/2)是整個canvas的中間取整,length/push的是蛇頭,unshift的是蛇尾
this.foodPosition = []; //儲存當(dāng)前食物的位置,這里每次都初始化為0
this.direction = 1; //方向:右1,下2,左3,上4
//畫畫布
this.ctx.fillStyle ="#fff";
this.ctx.fillRect(0,0,this.cellWidth*this.x,this.cellWidth*this.y);
this.drawSnake(); //記得寫this
this.drawFood();
this.setTime();
},
//蛇的移動
moveSnake: function(){
console.log(this); //window
console.log(this.snakeArr);
},
//定時器
setTime: function() {
// setTimeout(this.moveSnake.call(Snake),500); //為什么這樣指過去不行?
(function(theThis){
var that = theThis;
that.timer = setTimeout(function() {
that.moveSnake();
}, 500);
})(this);
},
}
老生常談
1.函數(shù)內(nèi)部的this
指向依賴于函數(shù)被調(diào)用的方式,setInterval
中的回調(diào)函數(shù)是在全局環(huán)境下調(diào)用的,因此this
指向window
2.Function.ptototype.call
綁定的是函數(shù)運(yùn)行時的this
,這里你將this
綁定到了Snake
上,但是Snake
是構(gòu)造函數(shù)而非實(shí)例,因此打印結(jié)果是Snake
構(gòu)造函數(shù)
3.你把this
當(dāng)參數(shù)傳進(jìn)IIFE
,并賦給了另外一個變量,因此這個變量就是this
4.之所以直接傳this
不行,是因?yàn)?code>setTimeout的回調(diào)函數(shù)本來就不會傳入?yún)?shù),因此你的形參this的值是undefined
解決方案有二
1.聲明一個變量保存this
,回調(diào)函數(shù)中直接調(diào)用這個變量的方法
2.使用箭頭函數(shù),自動綁定當(dāng)前作用域的this
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。