表
a = { } b = { x = 1, ["hello, "] = "world!" } a.astring = "ni, hao!" a[1] = 100 a["a table"] = b function foo() end function bar() end a[foo] = bar --分别穷举表a和b for k, v in pairs(a) do print(k, "=>", v) end print("----------------------------") for k, v in pairs(b) do print(k, "=>", v) end
--输出结果 1 => 100 a table => table: 003FB3A0 function: 003FCBB0 => function: 003FCBD0 astring => ni, hao! ---------------------------- hello, => world! x => 1
定义表(Table)的方式:a = {}, b = {…}
访问表的成员:通过“.”或者“[]”运算符来访问表的成员。注意:表达式a.b等价于a[“b”],但不等价于a[b]
local b = {"h", 20} --《=》 {[1]="h", [2]=20} 《=》local b={};b[1]="h";b[2]=20 local d = {x=0, y=0} --《=》local d = {}; d.x=0; d.y=0 《=》local d = {}; d["x"]=0; d["y"]=0
表项的键和值:任何类型的变量,除了nil,都可以做为表项的键。从简单的数值、字符串到复杂的函数、表等等都可以;同样,任何类型的变量,除了nil,都可以作为表项的值。给一个表项的值赋nil意味着从表中删除这一项,比如令a.b= nil,则把表a中键为“b”的项删除。如果访问一个不存在的表项,其值也是nil,比如有c = a.b,但表a中没有键为“b”的项,则c等于nil。
一种简单的对象实现方式
function CreateStudent(ID,Name) local Obj={id=ID,name=Name}; function Obj:GetID() return self.id; end function Obj.GetName(self) return self.name; end function Obj:SetID(ID) self.id=ID; end Obj.SetName=function(self,Name) self.name=Name end return Obj; ends1=CreateStudent(1,"andy"); print("s1'id=",s1:GetID(),"s1'name=",s1.GetName(s1))
s1:SetID(2); s1.SetName(s1,"lili"); print("s1'id=",s1:GetID(),"s1'name=",s1:GetName())
--输出结果 --s1'id= 1 s1'name= andy --s1'id= 2 s1'name= lili
对象工厂模式:如上面代码的create函数
用表来表示对象:把对象的数据和方法都放在一张表内,虽然没有隐藏私有成员,但对于简单脚本来说完全可以接受。
成员方法的定义:function obj:method(a1, a2, ...) … end <==>function obj.method(self, a1, a2, ...) … end <==>obj.method = function (self, a1, a2, ...) … end
成员方法的调用:obj:method(a1, a2, …) <==>obj.method(obj, a1, a2, ...)
简单继承
function CreateStudent(ID,Name) local Obj={id=ID,name=Name}; function Obj:GetID() return self.id; end function Obj.GetName(self) return self.name; end function Obj:SetID(ID) self.id=ID; end Obj.SetName=function(self,Name) self.name=Name end return Obj; endfunction CreateClassStudent(ID,Name,Class) local obj=CreateStudent(ID,Name); obj.class=4; function obj:GetClass() return self.class; end function obj.SetClass(self,class) self.class=class; end return obj; end
s2=CreateClassStudent(1,"andy",5); print("s2'class=",s2.GetClass(s2))
优点:简单、直观 缺点:传统、不够动态
本文向大家介绍Django学习笔记之ORM基础教程,包括了Django学习笔记之ORM基础教程的使用技巧和注意事项,需要的朋友参考一下 ORM简介 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术。 简单的说,ORM是通过使用描述对象和数据库之间映射的元数据,将程序中的对象自动持久化到关系数据
本文向大家介绍Lua基础教程之赋值语句、表达式、流程控制、函数学习笔记,包括了Lua基础教程之赋值语句、表达式、流程控制、函数学习笔记的使用技巧和注意事项,需要的朋友参考一下 赋值语句 注释,单行用(--)来表示;多行用(--[[ ... ]])来标示; 定义,lua中没有定义(申明数据类型),它是通过赋值来确定其数据类型的。 赋值,是改变一个变量的值和改变表域的最基本的方法。 a = "hell
本文向大家介绍seajs学习教程之基础篇,包括了seajs学习教程之基础篇的使用技巧和注意事项,需要的朋友参考一下 介绍 众所周知前端开发模块化已经是大势所趋,目前模块化的规范有很多,众所周知的有commonJS,Module/Wrappings和AMD等,而且ES6也着手开始制定模块化机制的实现。类似于c/c++的include,java中的import关键字,在js中也定义了require关键
本文向大家介绍AngularJS基础学习笔记之表达式,包括了AngularJS基础学习笔记之表达式的使用技巧和注意事项,需要的朋友参考一下 AngularJS通过表达式将数据绑定到HTML。 AngularJS表达式 AngularJS表达式写在双大括号中:{{ 表达式语句 }}。 AngularJS表达式绑定数据到HTML的方式与ng-bind指令的方式相同。 AngularJS会准
Lua 基础教程
本文向大家介绍Three.js基础学习教程,包括了Three.js基础学习教程的使用技巧和注意事项,需要的朋友参考一下 一、Three.js官网及使用Three.js必备的三个条件 1.Three.js 官网 https://threejs.org/ 2.使用Three.js必备的三个条件 (To actually be able to display anything with Three.js