浅析一个函数调用另一个函数的变量
js中一个函数中调用另一个函数,内部函数怎么访问外部函数的变量? 无意中逛到这个问题,突然发现自己以前也有这样的困惑
function a(){ alert(num); }
function b(){ var num=3;a();}
b(); //num is not defined
复制代码 a函数不是b的内部函数(闭包),而是全局函数。所以对于a函数来说,即使你b在内部调用了我a,我a还是访问不了你b。 说到底就是作用域问题,所以我想到了改变作用域的方法
call(),apply(),bind()
实现
function a(){ alert(num); }
function b(){ var num=3;a.call(b);}
b(); // num is not defined
复制代码 尝试了很多次,都无法获取到b,原来我对这些方法理解有误,查阅文档,发现此类方法主要作用是,对象调用不属于自己的方法,例如下例: food函数是没有product方法,使用call对food的上下文进行product操作
//mozilla官方用例
function Product(name, price) {this.name = name;this.price = price;
}function Food(name, price) {Product.call(this, name, price);this.category = 'food';
}function Toy(name, price) {Product.call(this, name, price);this.category = 'toy';
}
var cheese = new Food('feta', 5);
var fun = new Toy('robot', 40);复制代码 使用闭包
闭包就不多说了,一个函数内部定义(不是调用)另一个函数 内部函数可调用外部函数的变量,作用域链的延长
改写
function b(){ var num=3;function a(){ alert(num); }a();}
b(); //3
复制代码 传参
function a(num){ alert(num); }
function b(){ var num=3; a(num);}
b(); //3
复制代码 return
function a(){ alert(b()); }
function b(){ var num=3; return num;}a();
复制代码 总结
一般来说,a是复用的函数,才会有此类用法,传参实现即可。
参考资料
深入浅出妙用 Javascript 中 apply、call、bind 学习Javascript闭包(Closure) call()方法
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
