方法一:构造方法。
- function coder(){
- this.name = '小王';
- this.job = '程序员';
- 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 = '老王';
- alert(coder1.name); /*示“老王”*/
- alert(coder2.name); /*这个也显示“老王”*/
以上三种都有着各自的缺点,所以我们要加以改进。
- 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;
- }
- }