javascript 面向对象的JavaScript类


在上一节面 JavaScript 面向对象之命名空间 中说了怎么定义JavaScript命名空间,这一节来说下紧接着的一个概念——类。虽然JavaScript中没有class关键字,但作为开发人员我们一定要有这个思想。在C#中类可以分为实例类和静态类,JavaScript亦然。


一,定义实例类: 在上节中我定义了一个cnblogs.news的命名空间,现在就在此命名空间下定义一个名为Article类:

复制代码 代码如下:

cnblogs.news.Article=function(){
var _this=this;
this.title=null;
this.content=null;
this.show=function(){
document.write("<h1>"+_this.title+"</h1>");
document.write("<p>"+_this.content+"</p>");
}
}

创建对象就和C#一样:
复制代码 代码如下:

// 实例化一个对象
var article =new cnblogs.news.Article();
// 给对象的属性赋值
article.title="这是文章标题";
article.content="这是文章内容";
// 调用对象的方法
article.show();

二,定义静态类:所谓静态类就是直接调用类的成员,换言之,类的成员是属于类的,不属于对象。同样以Article为例,代码如下:
复制代码 代码如下:

cnblogs.news.Article={
title:"这是文章标题",
content:"这是文章内容",
show:function(){
document.write("<h1>"+cnblogs.news.Article.title+"</h1>");
document.write("<p>"+cnblogs.news.Article.content+"</p>");
}
};

调用方式也和C#类似:
cnblogs.news.Article.show();
到这里或许你已经发现了,所谓JavaScript静态类其实就是一个json对象,恭喜,答对了! ^_^
三,如何选择:
那么何时选择实例类,何时选择静态类呢,就个人经验而言(说得不对敬请斧正刀正,怎么正都可以^_^),开发一些对dom的依赖比较弱,而要求复用型很强的程序,如工具类,插件类,结构,使用静态类;反之如果程序对dom依赖很强,经常有变量传来传去,或者对类的结构造成变化,这时选用实例类。个人比较推崇第一种方案,其代码风格较之第二种更像C#,我想写惯了C#的同学也会这样觉得的,^_^。
作者: 祥叔



相关阅读:
Javascript 变量作用域 两个可能会被忽略的小特性
Oracle在虚拟化战争中能否胜出
(四)文本填充,边框,边界和位置属性2
PHP生成动态WAP页面
JQuery中each()的使用方法说明
用VBS模拟实现PHP的sha1_file函数效果代码
对javascript和select部件的结合运用
详解:虚拟主机IIS连接数知识
用PHP连mysql和oracle数据库性能比较
CSS实例:创建有图标的网站导航菜单
跳出惯性思维解决Linux上不了网的问题
C#教程:关于匿名类型的特性
Oracle10g新增CONVERT语法
Asp.net Mvc Framework 六 (更多的View传值及显示方式)
快速导航

Copyright © 2016 phpStudy |