Lua 模块的完整入门指南

一、什么是模块?

从本质上讲,Lua 模块就是存储在自己文件中的一段可复用代码。

二、创建你的第一个模块

黄金法则:模块就是一个返回(return)表的 Lua 文件。

让我们创建一个简单的数学工具模块。

  1. 创建一个名为 mymath.lua 的新文件。
  2. 在其中放入以下代码:
lua 复制代码
-- 文件:mymath.lua
-- 1. 创建一个局部表来保存我们模块的函数和数据。
--    使用 'M' 代表 'module' 是一个常见的约定。
local M = {}

-- 2. 定义函数并将它们添加到我们的表中。
--    这些函数现在是我们模块表的"方法"。
function M.add(a, b)
    return a + b
end

function M.subtract(a, b)
    return a - b
end

function M.multiply(a, b)
    return a * b
end

function M.divide(a, b)
    if b == 0 then
        return nil, "除数不能为零"
    end
    return a / b
end

-- 模块中可用的常量
M.PI = 3.14159
M.VERSION = "1.0.0"

-- 3. 最重要的步骤:在文件末尾返回这个表。
--    这使得其中的所有函数和数据对其他脚本可用。
return M

就是这样!你已经创建了一个模块。注意所有东西都整洁地保存在 M 表内。

三、使用 require 来使用你的模块

现在,我们使用内置的 require 函数在另一个文件中使用我们这个 mymath

  1. 同一目录 中创建另一个名为 main.lua 的文件。
  2. 在其中放入以下代码:
lua 复制代码
-- 文件:main.lua

-- 使用 'require' 来加载我们的模块。
-- 注意:你不需要包含 '.lua' 扩展名。
-- 'require' 返回 mymath.lua 返回的表。
local mymath = require("mymath")

-- 现在我们可以使用模块中的函数了!
local sum = mymath.add(10, 5)
print("和:", sum) -- 输出: 和: 15

local difference = mymath.subtract(10, 5)
print("差:", difference) -- 输出: 差: 5

local product = mymath.multiply(10, 5)
print("积:", product) -- 输出: 积: 50

local quotient, err = mymath.divide(10, 0)
if quotient then
    print("商:", quotient)
else
    print("错误:", err) -- 输出: 错误: 除数不能为零
end

-- 我们也可以访问模块中的数据。
print("圆周率约等于:", mymath.PI) -- 输出: 圆周率约等于: 3.14159
print("模块版本:", mymath.VERSION) -- 输出: 模块版本: 1.0.0

require 的工作原理:

  • 它搜索指定的模块文件(例如,mymath.lua)。
  • 它运行该文件内的代码只执行一次
  • 它存储(缓存)该模块文件 return 的值。
  • 如果你在其他地方再次 require 同一个模块,Lua 不会重新运行文件;它会立即给你缓存的返回值。这既智能又高效!

结语

点个赞,关注我获取更多实用 Lua 技术干货!如果觉得有用,记得收藏本文!

相关推荐
你的人类朋友17 小时前
✍️记录自己的git分支管理实践
前端·git·后端
合作小小程序员小小店17 小时前
web网页开发,在线考勤管理系统,基于Idea,html,css,vue,java,springboot,mysql
java·前端·vue.js·后端·intellij-idea·springboot
防火墙在线17 小时前
前后端通信加解密(Web Crypto API )
前端·vue.js·网络协议·node.js·express
Jacky-00817 小时前
Node + vite + React 创建项目
前端·react.js·前端框架
CoderYanger18 小时前
前端基础——CSS练习项目:百度热榜实现
开发语言·前端·css·百度·html·1024程序员节
i_am_a_div_日积月累_18 小时前
10个css更新
前端·css
倚栏听风雨19 小时前
npm命令详解
前端
用户479492835691519 小时前
为什么我的react项目启动后,dom上的类名里没有代码位置信息
前端·react.js
键盘飞行员19 小时前
Vue3+TypeScript项目中配置自动导入功能,遇到了问题需要详细的配置教程!
前端·typescript·vue
han_19 小时前
前端高频面试题之Vue(初、中级篇)
前端·vue.js·面试