javascript 写类方式之三_js面向对象

取前面两种的优点:
a、用构造函数来定义类属性(字段)
b、用原型方式来定义类的方法。
就有了第三种方式。这种方式貌似采用的人较多。
3、综合构造函数/原型

复制代码 代码如下:

/**
* Person类:定义一个人,有个属性name,和一个getName方法
* @param {String} name
*/
function Person(name) {
this.name = name;
}
Person.prototype.getName = function() {
return this.name;
}

这样,即可通过构造函数构造不同name的人,对象实例也都共享getName方法,不会造成内存浪费。
但似乎这样的代码风格似乎仍然没有java的类那么紧凑,把属性,构造方法(函数),方法都包在大括号内。

复制代码 代码如下:

public class Person {
//属性(字段)
String name;
//构造方法(函数)
Person(String name) {
this.name = name;
}
//方法
String getName() {
return this.name;
}
}

为了让js代码风格更紧凑,把挂在prototype的方法代码移到function Person的大括号内。

复制代码 代码如下:

function Person(name) {
this.name = name;
Person.prototype.getName = function() {
return this.name;
}
}

似乎很神奇,还能这么写啊!验证一下

复制代码 代码如下:

var p1 = new Person("Jack");
var p2 = new Person("Tom");
console.log(p1.getName());//Jack
console.log(p2.getName());//Tom

没有报错,控制台也正确输出了。说明可以这么写,呵呵。
嗯,似乎很完美。
a 、可以通过传参构造对象实例
b 、对象实例都共享同一份方法不造成内存浪费
c 、代码风格也比较紧凑
但每次new一个对象的时候都会执行
Person.prototype.getName = function() {
return this.name;
}
造成了不必要的重复的运算。因为getName方法挂在prototype上只需执行一次即可。只需稍微改造下:

复制代码 代码如下:

function Person(name) {
this.name = name;
if(Person._init==undefined) {
alert("我只执行一次!");
Person.prototype.getName = function() {
return this.name;
}
Person._init = 1;
}
}

new两个对象,

复制代码 代码如下:

var p1 = new Person("Andy");//第一次new会弹出'我只执行一次!'
var p2 = new Person("Lily");//以后new的对象不会再执行了

时间: 2024-09-23 10:33:51

javascript 写类方式之三_js面向对象的相关文章

javascript 写类方式之六_js面向对象

6.Prototype.js的写类方式 复制代码 代码如下: //prototype.js中的代码 var Class = { create: function() { return function() { this.initialize.apply(this, arguments); } } } //简化后的 function Clazz() { return function(){ this.initialize.apply(this,arguments); } } 如下步骤写一个类, 复

javascript 写类方式之四_js面向对象

4.构造函数 + 原型 直接组装一个类:同一构造函数将组装出同一类型通过前面几篇得知javascript写类无非基于构造函数 和原型 .既然这样,我们写个工具函数来写类. 复制代码 代码如下: /** * $class 写类工具函数之一 * @param {Object} constructor * @param {Object} prototype */ function $class(constructor,prototype) { var c = constructor || functi

javascript 写类方式之七_js面向对象

.dojo.js的写类方式 dojo最新是1.3.1了,记得07年时还是0.4.文档也渐渐多了起来,用dojo的也慢慢多了.dojo还发布了core版,压缩后只有27kb.dojo中用dojo.declare方法来定义一个类.dojo.declare的源码就不贴在这里了.dojo.declare有三个参数, 参数1:类名className 参数2:继承的类superclass 参数3:构造器,方法props 单纯的定义一个类实际只需传第一,三两个参数.因为这里只讨论如何定义一个类,不讨论继承.代

javascript 写类方式之八_js面向对象

8.Ext.js的写类方式 这里用的是Ext core3.0,Ext中用Ext.extend来定义一个类(当然它更多用来扩展一个类),Ext整个框架各种控件如Panel,MessageBox等都是用Ext.extend方法来扩展.这里仅仅用它来定义一个最简单的类. 看Ext.extend的代码可得知,它仍然是用构造函数和原型来组装一个类. 这里只需传两个参数即可,第一个参数是根类Object,第二个是原型. 复制代码 代码如下: /** * Person类 * @param {Object} n

javascript 写类方式之五_js面向对象

5.用 构造函数+原型 定义一个类:同一构造函数可以定义出多个类型 复制代码 代码如下: /** * $define 写类工具函数之二 * @param {Object} constructor * @param {Object} prototype */ function $define(constructor,prototype) { var c = constructor || function(){}; var p = prototype || {}; return function()

javascript 写类方式之一_js面向对象

EMCA262规范中没有类(class)的概念,js的new只是让他看起来更像c++,java一点.这里说的写类,只是书写js代码风格而已. 1.构造函数方式 复制代码 代码如下: /** * Person类:定义一个人,有个属性name,和一个getName方法 * @param {String} name */ function Person(name) { this.name = name; this.getName = function() { return this.name; } }

javascript 写类方式之十_js面向对象

10.mootools.js的写类方式 mootools.js的最新版本是1.2.3,这里使用的是1.2.0.mootool被设计成非常紧凑的,模块化的,面向对象的的js库.mootool中写类用Class类.Class类由Native类new出来的: 复制代码 代码如下: /* *Script: Class.js */ var Class = new Native({ name: 'Class', initialize: function(properties){ properties = p

javascript 写类方式之九_js面向对象

9.YUI的写类方式 这里引入的是YUI 2.7.0版,只需引入yahoo.js.YUI引入了命名空间,类似于java的包.以下yahoo的工具函数包 YAHOO.namespace YAHOO.lang YAHOO.lang.hasOwnProperty YAHOO.lang.extend YAHOO.lang.augment YAHOO.log YAHOO_config and YAHOO.env YUI Module Names 写类方式: 复制代码 代码如下: //定义包名 YAHOO.

如何在JavaScript中实现私有属性的写类方式(一)_javascript技巧

之前讨论过JavaScript中的写类方式.但没有讨论私有的实现.这篇看下. 我们知道JS中私有属性的实现本质就是 var + closure.如下 复制代码 代码如下: function Person(n, a){     // public     this.name = n;     // private     var age = a;     this.getName = function(){         return this.name;     }     this.getA