js 闭包

本文详细解析了JavaScript中闭包的概念,解释了闭包如何读取其他函数内部变量,以及其在函数内外部变量连接中的作用。同时,文章还提到了使用闭包时应注意的内存消耗和变量修改的问题。

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

闭包就是能够读取其他函数内部变量的函数。
 
由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成"定义在一个函数内部的函数"。
 
所以,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。
 
 
varBook=(function(){
//静态资源变量
var press="中央出版社";
//静态方法
var text=function(){};
function _book(id,content,name){
//私有属性
var name=press+"";
//私有方法
var checkBook=function(){
console.log('-------'+name);
}
//特权方法
this.setContent=function(){};
this.getContent=function(){};
//公有属性
this.id=id;
this.setContent(content);
//共有方法
this.test=function(name){
console.log('--++++'+press+name);
}
}
_book.prototype={
test2:function(){ console.log("prototype");}
}
return _book;
})();
var book=newBook(12,'内容','名字');
console.log(book.id);
book.test('name');
book.test2();
console.log(Book.name);

  

使用闭包的注意点:
1)由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。
2)闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。

转载于:https://www.cnblogs.com/QQ-Monarch/p/7229159.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值