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 ...
随机推荐
- iOS边练边学--图片的拉伸
图片拉伸方法一: IOS 5.0以后才有的方法: - (void)viewDidLoad { [super viewDidLoad]; UIImageView *imageView = [[UIIma ...
- zipkin使用mysql保存数据
zipkin和mysql结合保存zipkin在项目监控中得到的所有数据. <dependency> <groupId>io.zipkin.java</groupId> ...
- Game Loop的几种实现方式
http://www.bennychen.cn/2011/06/game-loop-model/ —————————————————————————————— 写这篇博客的目的是为了对game loo ...
- Omnigraffle快捷键
cmd+shift+. 和 cmd+shift+, 放大缩小 按住z点击鼠标是放大, z+Option是缩小 按住command双指推移 缩放 按住command,旋转物体 按住 option缩放 ...
- 解析 Spring ConversionService
弄了张图,方便以后一眼能想起是怎么回事. 前提,看这里:Spring Framework 官方文档学习(四)之Validation.Data Binding.Type Conversion(二) .
- (转)MPEG4码流简单分析
把MPEG4码流的分析和它的I,P,B Frame的判定方法在这里简要记录一下吧,供日后的翻看和大家的参考. 测试解码器测试了很久,由于需要将H264和MPEG4的码流进行分析和判断,并逐帧输入解 ...
- bootstrap -- css -- 表单控件
若干css样式 .form-control { display: block; width: 100%; height: 34px; padding: 6px 12px; font-size: 14p ...
- JavaScript DOM 第3章 DOM
3.4.5 获取元素 1. getElementById DOM提供了一个名为getElementById的方法,这个方法将返回一个与那个有着给定的id属性值的元素节点对应的对象. 文档中的每个元素都 ...
- 你是否有遇到过某个实体类字段(属性)过多的情况,不想每次点的话戳进来(C# 反射)
贴上一段代码: bureaucraticEntities apply = new bureaucraticEntities(); Type tapp= app.GetType(); Type ttmp ...
- c++ json cpp
一 编译链接 1 在相应官网下载jsoncpp 2 解压得到jsoncpp-src-0.5.0文件 3 打开jsoncpp-src-0.5.0 -> makefiles -> vs71 - ...