問(wèn)題一:我在一個(gè)構(gòu)造函數(shù)里寫(xiě)了setTime()方法和moveSnake方法,在setTime()里面用setInterval調(diào)用moveSnake方法,此時(shí)為什么this指向的是window?
問(wèn)題二: 我在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è)構(gòu)造函數(shù)呢?
那為什么我直接把this當(dāng)成參數(shù)傳給setTimeout不行呢:
var timeTest = setTimeout(function(this) {
this.moveSnake();
},500);
這個(gè)樣子就是Unexpected token this了
以下是這一部分的代碼,其他不相關(guān)的沒(méi)有貼出:
function Snake(id, score, speed, x, y){
this.id = document.getElementById(id);
this.ctx = this.id.getContext("2d");
this.cellWidth = 10; //每個(gè)格子的大小
this.score = document.getElementById(score);
this.speed = document.getElementById(speed);
this.x = x;
this.y = y;
// 畫(huà)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)]]; //蛇身長(zhǎng)度。初始化時(shí)只有兩個(gè)長(zhǎng)度,每一個(gè)點(diǎn)存了[x,y]兩個(gè)坐標(biāo),parseInt(this.y/2)是整個(gè)canvas的中間取整,length/push的是蛇頭,unshift的是蛇尾
this.foodPosition = []; //儲(chǔ)存當(dāng)前食物的位置,這里每次都初始化為0
this.direction = 1; //方向:右1,下2,左3,上4
//畫(huà)畫(huà)布
this.ctx.fillStyle ="#fff";
this.ctx.fillRect(0,0,this.cellWidth*this.x,this.cellWidth*this.y);
this.drawSnake(); //記得寫(xiě)this
this.drawFood();
this.setTime();
},
//蛇的移動(dòng)
moveSnake: function(){
console.log(this); //window
console.log(this.snakeArr);
},
//定時(shí)器
setTime: function() {
// setTimeout(this.moveSnake.call(Snake),500); //為什么這樣指過(guò)去不行?
(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)行時(shí)的this,這里你將this綁定到了Snake上,但是Snake是構(gòu)造函數(shù)而非實(shí)例,因此打印結(jié)果是Snake構(gòu)造函數(shù)
3.你把this當(dāng)參數(shù)傳進(jìn)IIFE,并賦給了另外一個(gè)變量,因此這個(gè)變量就是this
4.之所以直接傳this不行,是因?yàn)?code>setTimeout的回調(diào)函數(shù)本來(lái)就不會(huì)傳入?yún)?shù),因此你的形參this的值是undefined
解決方案有二
1.聲明一個(gè)變量保存this,回調(diào)函數(shù)中直接調(diào)用這個(gè)變量的方法
2.使用箭頭函數(shù),自動(dòng)綁定當(dāng)前作用域的this
北大青鳥(niǎo)APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
北大課工場(chǎng)是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國(guó)家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國(guó)制造2025”,實(shí)現(xiàn)中華民族偉大復(fù)興的升級(jí)產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國(guó)職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開(kāi)發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dò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ù), 熟練的跨平臺(tái)面向?qū)ο箝_(kāi)發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開(kāi)發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開(kāi)發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開(kāi)發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問(wèn),美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。