2013-08-06 72 views
3

我看到Easeljs有兩個不同的教程,一個是David Rousset,一個是Lee Brimelow。我不確定哪個更好用,什麼區別。例1(大衛·魯塞):Easeljs模式 - 解釋差異

(function (window) { 
function Player(imgPlayer, x_start, x_end) { 
    this.initialize(imgPlayer, x_start, x_end); 
} 
Player.prototype = new createjs.BitmapAnimation(); 

// public properties: 

Player.prototype.alive = true; 

// constructor: 
Player.prototype.BitmapAnimation_initialize = Player.prototype.initialize; //unique to avoid overiding base class 

var quaterFrameSize; 

Player.prototype.initialize = function (imgPlayer, x_end) { 
    var localSpriteSheet = new createjs.SpriteSheet({ 
     images: [imgPlayer], //image to use 
     frames: { width:64, height:64, regX:32, regY: 32 }, 
     animations: { 
      walk: [0, 9, "walk", 4] 
     } 
    }); 

    createjs.SpriteSheetUtils.addFlippedFrames(localSpriteSheet, true, false, false); 

    this.BitmapAnimation_initialize(localSpriteSheet); 
    this.x_end = x_end; 

    quaterFrameSize = this.spriteSheet.getFrame(0).rect.width/4; 

    // start playing the first sequence: 
    this.gotoAndPlay("idle");  //animate 
    this.isInIdleMode = true; 

} 

Player.prototype.tick = function() { 
//specific tick function for the player 
} 

    window.Player = Player; 
} (window)); 

和例2(李布賴姆洛):

(function(window) { 

function Player(){ 


    // Adding the easeljs bitmap as a property of Player:  
    this.view = new createjs.Bitmap("assets/pics/player1.png") 

    // Setting som local parameters 
    var height   = stage.canvas.height; 
    var width   = stage.canvas.width; 
    var playerRadius   = 70; 
    var offset   = 200; 
    var x    = 0; 
    var y     = 0; 

    this.view.regX = this.view.regY = playerRadius; 

    // Adding the tickfunction below 
    this.view.onTick = tick; 



} 

function tick(e) { 

// 

} 

window.Player = Player; 
})(window); 

只是ingnore一個使用BitmapAnimation和一個只是一個基本的位圖。

在例1:

1)難道是更換線路相同的:這是什麼的

this.alive = true; 

2):

Player.prototype.BitmapAnimation_initialize = Player.prototype.initialize; //unique to avoid overiding base class 

Player.prototype.alive = true; 

做的,我不明白com換貨......

3)這是行添加到啓動用來初始化函數:

Player.prototype = new createjs.BitmapAnimation(); 

我不知道當新的播放器()例1中

4運行到底發生了什麼)將tick設置爲Player的屬性將意味着您必須在主tick函數中調用此tick函數,使用easljs中Ticker類的內置onTick事件處理函數會更好嗎(如示例2所示) ?

以上哪種模式是「最佳實踐」,爲什麼?

此外,這兩種模式都依賴於創建Player對象(並將Player對象設置爲窗口屬性)的main.js。爲了保持全局範圍內的所有內容或者能夠將此代碼用於例如node.js,最好將main.js包裝在對象中,並且將此Main對象傳遞給一個參數的功能,而不是窗口?

比方說,你讓這個主JS:

Main = { 
init: function() { 
    //set up and create Player 
    var player = new Player; 
}, 
//then adding som properties, variables to Main... for instance 
propA: 0 
} 

這是可能的/ feasable?兩個圖案之間

+0

這是個人喜好。選擇一個你理解並喜歡的並且用它來運行。我投票結束,因爲它太寬泛,主要是意見,而不是具體的事實來解答。 – WiredPrairie

回答

4

差異:

的兩個圖案(通常,如果用作意)不用於相同的目的。 第一種模式是繼承,第二種模式是MVC。 (谷歌模型視圖控制器模式)。 我個人主張第一種模式,因爲它也是EaselJS在內部使用的模式,所以您可能想在更大的項目中考慮MVC,而不是EaselJS應用程序(通常)。

另外:對於第二種模式,如果您想利用MVC和繼承,您很可能必須在某個時間點使用第一個模式,而且我個人從未見過沒有繼承的MVC項目。就我個人而言,我從來沒有在JS/EaselJS項目中的MVC模式中體驗過任何優勢(但可能有很多人不贊同這種觀點,並且我同意他們在大多數其他語言中,而不是JS)。


爲了回答您的其他問題:

  1. 不,它不會是相同的。如果你將this.alive = true;寫入了初始化方法,那麼你在整個代碼運行時都會得到相同的結果,但是嚴格地看,即使這樣做會和設置原型屬性不同(但是這深入到JS內部功能中) 。

  2. Player -class「繼承」從BitmapAnimation,而圖案(即在此情況下使用的EaselJS)規定,每個類設有一個initialize -method。因此,在爲播放器定義初始化方法之前,原始初始化方法被'保存'爲BitmapAnimation_initialize,稍後在新的初始化方法中調用,如下所示。

  3. 該行基本上「內噴射」(或繼承......但嚴格看到JS有沒有繼承的模式,至少不會像Java,C#,AS3,等...)都從BitmapAnimationPlayer功能,所以當你創建一個新玩家時,你可以使用:myPlayer.gotoAndPlay('animation'),但gotoAndPlay()實際上是從BitmapAnimation開始的一種方法。

  4. 真實的,它會更好地使用onTick..被自動調用如果對象是階段的孩子,tick可能仍然是從EaselJS的早期版本(也不太清楚,雖然)。

哪一種模式是「最佳實踐」:

我想說的是,第一模式是(FOR EASELJS)的最佳做法,因爲這是EaselJS用於其自身的模式類也是如此。 (有一些細微差別,例如像命名空間)。對於一個巨大的項目你可能會考慮MVC。

+0

謝謝@olsn,很好的回答。我對onTick和tick進行了更多的研究,發現onTick是「已棄用:贊成」tick「事件,將來會被刪除。」我不知道爲什麼,這是一個不錯的財產。當涉及到問題1時,我的意思是直接在Player對象上將this.alive屬性設置爲初始化方法之外的公共屬性,但我想這不起作用? –

+0

如果你將它設置在一個方法之外,它將是'function(window){...}'的一個屬性,所以它不會有任何效果,因爲這是一個匿名函數,你將無法處理後來。 - 「.prototye.XXX」方式將使它成爲「公共」屬性,所以當你創建一個播放器時,你可以檢查「myPlayer.isAlive」 - 還要注意,「public」和「private」不是那種JS目前支持它自己的。 – olsn

+0

第二個例子與MVC有什麼關係?我能看到的只是顯示模塊模式。 – Bergi