首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > JavaScript >

JS_静态对象/步骤/属性

2012-09-22 
JS_静态对象/方法/属性转自:http://www.cnblogs.com/poissonnotes/archive/2011/06/06/2073741.htmlJavasc

JS_静态对象/方法/属性
转自:
http://www.cnblogs.com/poissonnotes/archive/2011/06/06/2073741.html

Javascript语言的面向对象特征很弱,其他面向对象语言在创建类时只要使用关键字static即可指定类为静态类,Javascript没有提供static这样的关键字,要让Javascript也具有“静态”特性只有靠一些“奇技淫巧”了。

代码中列举了两种静态方法/属性的实现方式,一种是静态类的静态方法和属性,另一种是非静态类的静态方法和属性,代码说明都写在每行的代码注释里,这里就不重复了。


/***************************************** 方法一* 类、方法、属性都为静态类型* 不能创建实例*****************************************/var Time = {today: ‘2009-3-8′,weather: ‘rain’,show: function(){alert(‘Today is ‘ + this.today); }};  //静态对象可直接使用,无需创建实例alert(‘It is ‘ + Time.weather + ‘ today.’); Time.show();  //下面的代码会出错,因为静态类不能创建实例//var t = new Time();//t.show(); /***************************************** 方法二* 普通对象,同时拥有静态和非静态属性、方法* 可以用实例化* 注意:*   1.静态方法/属性使用类名访问*   2.非静态方法/属性使用实例名访问*****************************************/function Person(name) {//非静态属性this.name = name; //非静态方法this.show = function() {alert(‘My name is ‘ + this.name + ‘.’); }}//添加静态属性,人都是一张嘴Person.mouth = 1; //添加静态方法,哇哇大哭Person.cry = function() {alert(‘Wa wa wa …’); }; //[color=red]使用prototype关键字添加非静态属性,每个人的牙可能不一样多[/color]Person.prototype.teeth = 32;  //非静态方法必须通过类的实例来访问var me = new Person(‘Zhangsan’); //使用非静态方法、属性me.show(); alert(‘I have ‘ + me.teeth + ‘ teeth.’); //使用静态方法、属性Person.cry(); alert(‘I have ‘ + Person.mouth + ‘ mouth.’);

热点排行