在JavaScript高级程序设计中第五章引用类5.5.5节,118页,使用call()来扩充作用域的最大好处,就是对象不需要与方法有任何耦合关系。这其中对象和方法的耦合关系怎么理解啊?求大神帮忙解答。
在JavaScript高级程序设计中第五章引用类5.5.5节,118页,使用call()来扩充作用域的最大好处,就是对象不需要与方法有任何耦合关系。这其中对象和方法的耦合关系怎么理解啊?求大神帮忙解答。
javascript里的函数和对象关系比较微妙,比如一个函数
function sayColor() {
alert(this.color);
}
sayColor没有绑定到其他对象(这个函数是全局的),则this指代window。那么实际上sayColor函数就和window对象耦合在一起了。
类似的
var o = {};
o.sayColor = function () {
alert(this.color);
}
this就指代o对象了。
但call函数可以改变这个耦合,随意替换this的指代,如
window.color = "red";
var o = {
color: "blue"
};
function sayColor() {
alert(this.color);
}
sayColor(); //red
sayColor.call(this); //red
sayColor.call(window); //red
sayColor.call(o); //blue
8 回答4.7k 阅读✓ 已解决
6 回答3.4k 阅读✓ 已解决
5 回答2.8k 阅读✓ 已解决
5 回答6.3k 阅读✓ 已解决
4 回答2.2k 阅读✓ 已解决
4 回答2.8k 阅读✓ 已解决
3 回答2.4k 阅读✓ 已解决
假设现在有个对象
a = {name: 'isayme'}
, 如果想提供一个接口打印name
属性, 怎么做?方法1
, 给对象定义一个函数(当然也可以用原型链, 此处仅简单化):方法2
, 打印的函数不再作为a
的属性, 而是单独定义:比较两个方法,
方法2
中打印函数print
与对象a
完全无关(两者无依赖关系), 即低耦合
;方法1
中的print
是对象a
的属性, 两者有明显的依赖关系, 即高耦合
.注:
低耦合
/高耦合
是相对的概念~低耦合有什么优点呢?
假如又有一个对象
b = {name: 'heaven'}
也想打印他的name
, 怎么办?如果是
方法1
, 那么b
只好自己也加一个print
属性. 但这样就相当于每个对象都会有自己独立的print
函数, 重复的代码会加重后期维护困难;如果是
方法2
,b
只要这样print.call(b)
就可以了! 是不是很简单!