JavaScript 实现类的多种方法实例
2013-05-01 00:00
537 查看
构造方法
工厂方法
工厂方法和构造方法都有着一个相同的缺点,就是每创建一个实例,都会实例化该类的每个函数。
原型链
原型链有个缺点就是它所有属性都共享,只要一个实例改变其他的都会跟着改变。如:
混合方式
以上三种都有着各自的缺点,所以我们要加以改进。
动态原链
要解决前三种的缺点,还有一种方法。
function coder() { this.name = '现代魔法'; this.job = 'Web 开发者'; this.coding = function () { alert('我正在写代码'); } } var coder = new coder(); alert(coder.name); coder.coding();
工厂方法
function createCoderFactory() { var obj = new Object(); obj.name = '现代魔法'; obj.job = '程序员'; obj.coding = function () { alert('我正在写代码'); }; return obj; } var coder = createCoderFactory(); alert(coder.name); coder.coding();
工厂方法和构造方法都有着一个相同的缺点,就是每创建一个实例,都会实例化该类的每个函数。
原型链
function coder(){} coder.prototype.name = '现代魔法'; coder.prototype.job = '程序员'; coder.prototype.coding = function(){ alert('我正在写代码'); }; var coder = new coder(); alert(coder.name); coder.coding();
原型链有个缺点就是它所有属性都共享,只要一个实例改变其他的都会跟着改变。如:
var coder1 = new coder(); var coder2 = new coder(); alert(coder1.name); /*显示现代魔法*/ coder2.name = 'nowamagic'; alert(coder1.name); /*显示nowamagic*/ alert(coder2.name); /*这个也显示nowamagic*/
混合方式
以上三种都有着各自的缺点,所以我们要加以改进。
function coder() { this.name = '现代魔法'; this.job = '程序员'; } coder.prototype.coding = function(){ alert('我正在写代码'); };
动态原链
要解决前三种的缺点,还有一种方法。
function coder() { this.name = '现代魔法'; this.job = '程序员'; if (typeof(coder._init) == 'undefined') { this.coding = function () { alert('我正在写代码'); }; this._init = true; } }
相关文章推荐
- javascript小实例,多种方法实现数组去重问题
- javascript小数四舍五入多种方法实现
- javascript实现html页面之间参数传递的四种方法实例分析
- JavaScript实现的类字典插入或更新方法实例
- 实例讲解javascript实现异步图片上传方法
- javascript小实例,编写一个方法,实现从n-m个数中随机选出一个整数
- javascript实现保留两位小数的多种方法
- javascript另类方法实现htmlencode()与htmldecode()函数实例分析
- javascript实现html页面之间参数传递的四种方法实例分析
- javascript中去除数组重复元素的实现方法【实例】
- JavaScript实现的类字典插入或更新方法实例
- JavaScript实现动态添加,删除行的方法实例详解
- javascript实现数组去重的多种方法
- Java实例说明 字符串的反转实现方法多种
- JavaScript实现动态添加,删除行的方法实例详解
- 从头到尾讲Webpack-实例篇(多种方法实现)
- javascript实现保留两位小数的多种方法
- JavaScript 多种方法实现类(转)