Egret类class和module写法区别
普通类
Test.ts
class Test { public name:string = "Test"; public run(){ console.log(this.name); } } var test:Test = new Test();
编译后的Test.js
var Test = (function () { function Test() { this.name = "Test"; } var d = __define,c=Test,p=c.prototype; p.run = function () { console.log(this.name); }; return Test; }()); egret.registerClass(Test,'Test');
Test2.ts
module Test2 { export class Test2{ public name: string = "Test2"; public run() { console.log(name); } } }var test2:Test2 = new Test2.Test2();
编译后的Test2.js
var Test2; (function (Test2_1) { var Test2 = (function () { function Test2() { this.name = "Test2"; } var d = __define,c=Test2,p=c.prototype; p.run = function () { console.log(name); }; return Test2; }()); Test2_1.Test2 = Test2; egret.registerClass(Test2,'Test2.Test2'); })(Test2 || (Test2 = {}));
静态类
Test.ts
class Test { public static name:string = "Test"; public static run(){ console.log(this.name); } }Test.run();
编译后的Test.js
var Test = (function () { function Test() { } var d = __define,c=Test,p=c.prototype; Test.run = function () { console.log(this.name); }; Test.name = "Test"; return Test; }()); egret.registerClass(Test,'Test');
Test2.ts
module Test2 { var name:string = "Test2"; export function run(){ console.log(name); } }Test2.run();
编译后的Test2.js
var Test2; (function (Test2) { var name = "Test2"; function run() { console.log(name); } Test2.run = run; })(Test2 || (Test2 = {}));
RegisterClass.ts
export function registerClass(classDefinition:any, className:string, interfaceNames?:string[]):void { if (DEBUG) { if (!classDefinition) { $error(, "classDefinition"); } if (!classDefinition.prototype) { $error(, "classDefinition") } ) { $error(, "className"); } } var prototype:any = classDefinition.prototype; prototype.__class__ = className; var types = [className]; if (interfaceNames) { types = types.concat(interfaceNames); } var superTypes = prototype.__types__; if (prototype.__types__) { var length = superTypes.length; ;i<length;i++){ var name = superTypes[i]; ){ types.push(name); } } } prototype.__types__ = types; }
Egret类class和module写法区别的更多相关文章
- CSS 属性 :before && :after的用法,伪类和伪元素的区别
一::before && :after的用法 :before 如同对伪元素的名称一样,:before 是用来给指定的元素的内容前面插入新的内容.举例说明: .before:before ...
- 详解 CSS 属性 - 伪类和伪元素的区别[转]
首先,阅读 w3c 对两者的定义: CSS 伪类用于向某些选择器添加特殊的效果. CSS 伪元素用于将特殊的效果添加到某些选择器. 可以明确两点,第一两者都与选择器相关,第二就是添加一些“特殊”的效果 ...
- 详解 CSS 属性 - 伪类和伪元素的区别(再也不用概念盲了!!!)
首先,阅读 w3c 对两者的定义: CSS 伪类用于向某些选择器添加特殊的效果. CSS 伪元素用于将特殊的效果添加到某些选择器. 可以明确两点,第一两者都与选择器相关,第二就是添加一些“特殊”的效果 ...
- 《转载》详解 CSS 属性 - 伪类和伪元素的区别
首先,阅读 w3c 对两者的定义: CSS 伪类用于向某些选择器添加特殊的效果. CSS 伪元素用于将特殊的效果添加到某些选择器. 可以明确两点,第一两者都与选择器相关,第二就是添加一些“特殊”的效果 ...
- CSS之 :before && :after的用法,伪类和伪元素的区别
一::before && :after的用法 :before 如同对伪元素的名称一样,:before 是用来给指定的元素的内容前面插入新的内容.举例说明: .before:before ...
- C++ 类对象和 指针的区别
C++ 类对象和 指针的区别 C++ 类对象和 指针的区别 转自:http://blog.csdn.net/ym19860303/article/details/8557746 指针的情况 class ...
- EF4.0和EF5.0增删改查的写法区别及执行Sql的方法
EF4.0和EF5.0增删改查的写法区别 public T AddEntity(T entity) { //EF4.0的写法 添加实体 //db.CreateObjectSet<T>(). ...
- 类和ID选择器的区别
学习了类选择器和ID选择器,我们会发现他们之间有很多的相似处,是不是两者可以通用呢?我们不要着急先来总结一下他们的相同点和不同点: 相同点:可以应用于任何元素不同点: 1.ID选择器只能在文档中使用一 ...
- Java中String类两种实例化的区别(转)
原文:http://blog.csdn.net/wangdajiao/article/details/52087302 一.String类的第一种方式 1.直接赋值 例:String str = &q ...
随机推荐
- rails路由
web敏捷开发 p317 depot > ruby script/console >>rs = ActionController::Routing::routes 可以简单测试 比如 ...
- imx6 读取CPU温度
imx6 读取CPU温度 cat /sys/class/thermal/thermal_zone0/temp Tony Liu 2017-2-11, Shenzhen
- Oracle数据库表空间与用户的关系是 ( )
Oracle数据库表空间与用户的关系是 ( )? A.一对一 B.一对多 C.多对一 D.多对多 解答: D 一个用户可以使用一个或多个表空间,一个表空间也可以供多个用户使用.
- IOC关注服务(或应用程序部件)是如何定义的以及他们应该如何定位他们依赖的其它服务
IOC关注服务(或应用程序部件)是如何定义的以及他们应该如何定位他们依赖的其它服务.通常,通过一个容器或定位框架来获得定义和定位的分离,容器或定位框架负责: 保存可用服务的集合 提供一种方式将各种部件 ...
- web 开发之酷炫--- 酷炫展示
http://www.cnblogs.com/dsxniubility/p/4588560.html
- C++字符串类型和数字之间的转换
转载:http://www.cnblogs.com/luxiaoxun/archive/2012/08/03/2621803.html 1.字符串数字之间的转换 字符串---字符数组(1)string ...
- Java回调方法的设计思路
package com.test; /** * 回调方法的设计技巧,例如hibernate的getHibernateTemplate().execute(Handler h)方法 */ public ...
- C#控件方法及属性大全,望补充
C#控件及常用设计整理 1.窗体 常用属性 (1)Name属性:用来获取或设置窗体的名称,在应用程序中可通过Name属性来引用窗体. (2) WindowState属性: 用来获取或设置窗体的窗口状态 ...
- win7 安装 VMware 出错解决办法
win7旗舰版安装VMware,安装过程中发生了如下错误.系统提示:“You may not install this product in the root directory of any dri ...
- centos上编译bitcoin
需要预先安装的东西 autoconf automake labtool openssl-devel boost-devel libevent