理解原型模式的缺陷以及理解对象相等的确切含义

function Campus(location, name) {
    this.location = location;
    this.name = name;
    this.information = information;
}

function information() {
    return this.location + ", " + this.name;
}

var aaa = new Campus('武汉', '武汉大学');
var bbb = new Campus('北京', '北京大学');
/**
 * 这是一个绝佳的理解对象相等的案例
 */
console.log(aaa === bbb);
console.log(aaa.location + ', ' + bbb.location);
console.log(aaa.information === bbb.information);

/**
 * 构造函数模式虽然解决了类型问题
 * 但是每一个对象中都存在独立的不共享的information对象
 * 解决方案就是将对象方法定义成全局方法。
 * 但是问题又来了,这地定义在全局环境中的全局方法information()
 * 无法使用,原因是information的意义依赖于Campus中的属性。
 * 脱离了campus,那么也就失去了价值,完全只是一个玩具方法。
 * 而且定义在全局中造成干扰。
 */

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值