Kevin Cheng's Yard
电脑是我的老婆,编程是我的灵魂,代码是我的语言,按键是我在歌唱。
随笔- 54  文章- 0  评论- 249 
博客园  首页  新随笔  联系  管理  订阅 订阅

javascript 类和命名空间的模拟

就当我是重复造轮子吧,整理该文档给有需要的人用,包括我:)

先上一段最简单的:

// 以下几行代码展示了命名空间、类、以及函数的模拟定义和使用:
NameSpace = {};
NameSpace.Class 
= function(){
  
this.Method = function(info){alert(info);}
};
new NameSpace.Class().Method("Hello world");

 

 

再来一些可见到的,各种情况的代码

1.类的模拟

  // 类定义
  function Class(info){
    
// 私有成员
    var privateData = "private data";
    
var privateMethod = function(){writeline("private");};
    
function privateMethod2(info){writeline("private");}

    
// 公有成员(使用this)
    this.Data = "public data";
    
this.Method = function(){writeline(info);};
  };
  
  
// 类的静态成员
  Class.StaticData = "static data";
  Class.StaticMethod 
= function(info){writeline(info);};

 

 

2.命名空间的模拟

function NameSpace(){}
或者
NameSpace 
= {};
或者
NameSpace 
= new Object();

 


3.目标:创建类实例,并调用实例方法

var o = new NameSpace.Class("hello world");

o.Method();

  // 使用已有的类定义,并用静态方法挂到NameSpace下
  NameSpace.Class1 = Class;
  
new NameSpace.Class1("new NameSpace.Class1().Method()").Method();

  
// 或者:新建类定义
  NameSpace.Class2 = function(info){
    
this.Method = function(){writeline(info);};
  };
  
new NameSpace.Class2("new NameSpace.Class2().Method()").Method();

 

 

4.目标:调用类的静态函数

NameSpace.Class.StaticMethod();

  // 静态对象+静态方法
  NameSpace.Class3 = {};  // {}表示这是一个对象,或者用new object();
  NameSpace.Class3.Method = function(info) {writeline(info);};
  NameSpace.Class3.Method(
"NameSpace.Class3.Method()");

  
// 或者:new一个对象赋予静态成员
  NameSpace.Class4 = new Class("NameSpace.Class4.Method()");
  NameSpace.Class4.Method();
  
  
// 或者:匿名函数用于定义类,再用new创建对象
  NameSpace.Class5 = new (function(info){
    
this.Method = function(){writeline(info);};
  })(
"NameSpace.Class5.Method()");
  NameSpace.Class5.Method();
  
  
// 或者:JSON方式(类定义+创建同时完成)
  // 优点是简单,缺点是不能传递参数进去
  NameSpace.Class6 = {
    Method : 
function(info){writeline(info);}
  };
  NameSpace.Class6.Method(
"NameSpace.Class6.Method()");

 

代码下载:/Files/surfsky/oo.htm

ps.很开心,vs2010对js的智能感知越来越好用了:p

 

转载请注明出处:http://surfsky.cnblogs.com 

标签: javascript oo 类 对象 命名空间
绿色通道:好文要顶关注我收藏该文与我联系
posted @ 2010-10-19 16:12 Kevin Cheng 阅读(179) 评论(1) 编辑 收藏
发表评论
1960560
 回复 引用 查看   
#1楼2010-11-15 09:55 | imba      
感觉js过于灵活
注册用户登录后才能发表评论,请 登录 或 注册,返回博客园首页。
首页博问闪存新闻园子招聘知识库
最新IT新闻:
· 谷歌将出售Clearwire股份 不到收购价1/10
· 为什么Google比苹果更令微软恐惧?
· 思科拟2.71亿美元收购私有公司Lightwire
· 社交商务公司Bazaarvoice将于2月24日进行IPO
· 戴尔收购备份软件公司AppAssure
» 更多新闻...
最新知识库文章:
· 领域模型管理与AOP
· 编程的艺术:漂亮的代码和漂亮的软件
· GIT分支管理是一门艺术
· 编程:是一门艺术
· 编程是一门艺术吗?
» 更多知识库文章...

China-pub 2011秋季教材巡展
China-Pub 计算机绝版图书按需印刷服务
Copyright ©2012 Kevin Cheng
精于斯,乐于斯。
昵称:Kevin Cheng
园龄:6年3个月
粉丝:20
关注:1
<2010年10月>
日一二三四五六
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

搜索

 
 

常用链接

  • 我的随笔
  • 我的评论
  • 我的参与
  • 最新评论
  • 我的标签
  • 更多链接

我的标签

  • Rss RssItem RssChannel XmlSerializer(1)
  • MVC ASP.NET Razor(1)
  • MVC Razor ASP.NET(1)
  • MVC ASP.NET(1)
  • javascript oo 类 对象 命名空间(1)
  • ASP.NET MVC SKIN 换肤(1)
  • Silverlight WPF(1)

随笔分类

  • 日子(3)
  • .NET(14)
  • .NET组件控件(15)
  • IT新闻(1)
  • 报表开发(1)
  • 代码生成器(1)
  • 工作流引擎
  • 建模与快速开发 (5)
  • 数据库 (4)
  • 杂项(7)

随笔档案

  • 2010年12月 (1)
  • 2010年11月 (1)
  • 2010年10月 (6)
  • 2010年8月 (7)
  • 2010年6月 (3)
  • 2009年12月 (1)
  • 2009年11月 (2)
  • 2009年5月 (2)
  • 2008年12月 (1)
  • 2008年8月 (1)
  • 2008年7月 (1)
  • 2007年12月 (1)
  • 2007年6月 (1)
  • 2007年5月 (1)
  • 2007年3月 (2)
  • 2007年1月 (1)
  • 2006年12月 (1)
  • 2006年11月 (1)
  • 2006年10月 (1)
  • 2006年9月 (1)
  • 2006年8月 (3)
  • 2006年6月 (5)
  • 2006年3月 (2)
  • 2006年2月 (1)
  • 2005年12月 (7)

文章分类

  • .NET(1)

相册

  • 回忆

Blogs

  • DbToCode
  • RapidTier
  • SmartPersistenceLayer
  • 灵感之源

NET WebSite

  • ASP.NET
  • CodeProject
  • CSDN
  • GoDotNet
  • MSDN
  • SourceForge

Special

  • icsharpcode.com
  • Open License
  • Python

最新评论

阅读排行榜

评论排行榜

推荐排行榜