JavaScript设计模式_创建对象的安全模式

本文探讨了JavaScript中构造函数的使用方式及实例化过程中new关键字的作用。通过示例代码讲解了不使用new关键字时构造函数如何意外地将属性附加到window对象上,并提出了一种安全创建对象的方法来避免此类问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

window.onload=function(){
			var Book=function(title,time,type){
				this.title=title;
				this.time=time;
				this.type=type;
			}
			var book=Book("JavaScript","2014","js");
			console.log(book);//undefined
                        console.log(window.title);//JavaScript
                        console.log(window.time);//2014
                        console.log(window.type);//js
		}

未使用new关键词进行实例化,new关键字的作用是对当前this对象的不断赋值(即更新当前this的指向),然而上述代码没有使用new关键字,所以此时的this指向的当前对象是window,所以这些属性就被添加到window上,而book变量最终作用是得到Book这个函数的执行结果(return的返回值),由于函数中未定义返回值,所以book变量执行结果为undefined。

 

安全模式创建对象:

      var Book2=function(title,time,type){
      	if(this instanceof Book2){//加入原型判断,判断this是否属于Book2类型,如果是则说明是new创建的Book2的一个实例对象
            this.title=title;
            this.time=time;
            this.type=type;
      	}else{
           return new Book2(title,time,type);//非new创建的实例对象,重新创建一个实例对象
      	}				
      }
      var book2=Book2("HTML","2016","web");
      console.log(book2);//undefined
      console.log(window.title);//JavaScript
      console.log(window.time);//2014
      console.log(window.type);//js

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值