Skip to main content

[Lua] 一分鐘搞懂 Corona SDK 中 「.」與「:」執行函式時的差別



之前有網友在 台灣可樂娜跨平台基地 - Corona SDK 上詢問 Corona SDK 中 table listener 與 function listener 差別。

其實 :addEventListener 時並沒有強制一定需要使用 table listener,因為它在執行 listener 函式時,對於 table 物件會使用 tableObj:listenerFunc ,而單純的 function 是正常執行 listenerFunc() ,差別是 function listener 不會因為「:」語法糖而將 table 本身帶入。
其實只要看下面範例就可以馬上清楚知道其中的差別:

local rect1 = display.newRect( 20, 20, 50, 50 )
rect1.name = "Rect1"

local rect2 = display.newRect( 100, 20, 50, 50 )
rect2.name = "Rect2"

local function onTouch1(self, event)
print(self.name)
end

local function onTouch2(event)
local self = event.target
print(self.name)
end

rect1.touch = onTouch1
rect1:addEventListener("touch", rect1 )

rect2:addEventListener("touch", onTouch2 )


以上沒有限定一定要如何宣告,端看你需要函式幫你做什麼而定。

同理下面兩個函式宣告是同等的:

function rect1:touch(event)
print(self.name)
end

rect1.touch = function(self, event)
print(self.name)
end
rect1:addEventListener("touch", rect1 )


可以看出「.」與「:」的差別了嗎?

最後一個範例:


local object = {name='Corona'}

-- 這是一般 table function 宣告方法
function object:sayHaha()
print(self.name..":Haha...")
end

object:sayHaha()
-- output: Corona:Haha...

object.sayHelo = function(self)
print(self.name..":Hello.")
end

object:sayHelo()
-- output: Corona:Hello.

-- 而不是
object.sayHelo()
-- output error self is nil

object.say = function(string)
print(string)
end

object.say("Lua is fun.")
-- output: Lua is fun.

-- 而不是
object:say("Lua is fun.")
-- 因為:的關係第一個屬性會被帶入 object 所以 output: table: 0x10d01c490

Comments

Popular posts from this blog

PureMVC 我也會 [6]

Mediator ViewComponents 與 pureMVC 架構的中介 監聽並反應 View Component 發出的 Event 可以發送與接收 Notification 儘量少操作 Proxy 公開方法,多用 sendNotification... Mediator design pattern 要多認識這個 Mediator 設計模式的話,請自行看連結說明啊! 簡單來講,假使有一個 View 裡面有好幾個 MovieClip 組成,而這些 MovieClip 會互相影響對方...這個情況在 Flash 中,通常都會變成下圖: MovieClip 直接控制其他 MovieClip 搞到整個關係很複雜...換一個元件簡直是災難。 加入 Mediator 後,示意圖就會變成: 這樣,所有的 MovieClip 都透過 Mediator 來跟其他 MovieClip 溝通,當某一個 MovieClip 替換成別的元件,這時候也只需要修改 Mediator 中的引用即可,是不是變得很乾淨?如果同一組 MovieClip 有另外一個操作模式,也只需要替換掉 Mediator 即可!天下太平啊~~~ 而 PureMVC 中就是利用 Mediator class 為與前端 ViewComponent 的中介,這樣可以切開 ViewComponent 與 PureMVC framework 的關係,不管你前端介面使用 Flash or Flex 製作都跟程式核心無關。 所以 ViewComponent 製作時只需要兩個原則,一把所有的請求都以 Event 送出由 Mediator 處理,二提供公開方法, Mediator 只需要監聽 View 的 Event,將收到的資訊透過公開方法喂進 ViewComponent 即可。 如在 ViewComponent 中: public function setList( result:Object ):void{ list.dataProvider = result as ArrayCollection; } //然後在按下取得資料的按鈕 Click action 寫上: dispatchEvent( new Event( "GET_LIST" )); 新建 Mediator 的時候一樣有幾個重點方...