模塊是一個像,可以使用需要加載并有包含表中的單個全局命名的庫。該模塊可包含若干函數(shù)和變量。所有這些函數(shù)和變量被包裹在以它作為一個命名空間的表。也是一個很乖的模塊有必要的規(guī)定,返回此表上所需要的。
表中的模塊的使用可以幫助我們以多種方式,使我們能夠操縱模塊中我們操縱任何其他lua的表相同的方式。作為操縱模塊的能力的結(jié)果,它提供了額外的功能的量等語言需要特殊的機制。由于lua模塊,這個免費的方式下,用戶可以調(diào)用Lua函數(shù)以多種方式。如下面幾個:
-- Assuming we have a module printFormatter -- Also printFormatter has a funtion simpleFormat(arg) -- Method 1 require "printFormatter" printFormatter.simpleFormat("test") -- Method 2 local formatter = require "printFormatter" formatter.simpleFormat("test") -- Method 3 require "printFormatter" local formatterFunction = printFormatter.simpleFormat formatterFunction("test")
在上面的示例代碼中,可以看到如何靈活的編程Lua是沒有任何特殊的額外的代碼。
Lua提供了一個名為規(guī)定加載所有必要的模塊高級函數(shù)。它被保持盡可能的簡單,以避免對模塊太多的信息,以將其加載。該規(guī)定函數(shù)只是假定模塊作為一個代碼塊定義一些值,這實際上是函數(shù)或者包含函數(shù)表。
讓我們考慮一個簡單的例子,其中一個函數(shù)具有數(shù)學(xué)運算功能,并允許調(diào)用此模塊作為mymath和文件名是mymath.lua。該文件的內(nèi)容如下。
local mymath = {} function mymath.add(a,b) print(a+b) end function mymath.sub(a,b) print(a-b) end function mymath.mul(a,b) print(a*b) end function mymath.div(a,b) print(a/b) end return mymath
現(xiàn)在為了訪問該lua模塊中的另一個文件moduletutorial.lua,則如下所示。
mymathmodule = require("mymath") mymathmodule.add(10,20) mymathmodule.sub(30,20) mymathmodule.mul(10,20) mymathmodule.div(30,20)
為了運行這些代碼,我們需要把在同一個目錄下2 個lua文件,或者也可以放在包路徑的模塊文件,并需要產(chǎn)生額外的設(shè)置。當我們運行上面的程序,會得到下面的輸出。
30 10 200 1.5
現(xiàn)在重新編寫相同的例子,其中使用包舊的方式。查看所有類型的實現(xiàn)。這是在使用Lua版本5.1和5.0。math模塊如下所示。
module("mymath", package.seeall) function mymath.add(a,b) print(a+b) end function mymath.sub(a,b) print(a-b) end function mymath.mul(a,b) print(a*b) end function mymath.div(a,b) print(a/b) end
moduletutorial.lua模塊的使用情況如下所示。
require("mymath") mymath.add(10,20) mymath.sub(30,20) mymath.mul(10,20) mymath.div(30,20)
當我們運行上面,我們會得到相同的輸出。但建議在使用代碼的舊版本,它被認為不太安全。使用Lua中像Corona SDK 編程的許多軟件開發(fā)工具包已經(jīng)過時。