js 闭包范式概述
2020-12-13 03:38
标签:闭包 私有化 js json 在前几篇文章中我介绍过js的闭包,这一篇主要简单的介绍一下js中闭包的范式。 那么何谓闭包的范式呢? 首先回顾一下闭包的概念,闭包是外部函数与函数内部之间通信的桥梁,通过对函数的返回,使得外部的函数可以访问函数内部的 一些数据。也就是说闭包可以使得函数内部的数据私有化或者说是公有化。 范式实际上就是js中的匿名函数,看起来像这样,下面就是个匿名函数,也就是闭包
上面讲过闭包可以实现数据的私有化和公有化,那么范式如何解决这个问题呢?我在这里举一个简单的例子:
js 闭包范式概述,搜素材,soscw.com js 闭包范式概述 标签:闭包 私有化 js json 原文地址:http://blog.csdn.net/andywuchuanlong/article/details/25720041 (function(){
})()
既然是函数,那同样也可以传递参数,在匿名函数中的参数传递看起来像下面这样子:
(function(b){
})(a)
其中a是实参,b是形参。当让我们也可以传递多个参数了。
(function(window){
var name = ‘function‘;
function getFunctions(){
return {
fb:fb,//公开的函数
fc:fc
};
}
function fa(){
console.info(‘fa‘);
}
function fb(){
console.info(‘fb‘);
}
function fc(){
console.info(‘fc‘);
}
function fd(){
console.info(‘fd‘);
}
window.getFunctions = getFunctions();
})(window);
console.info(window.getFunctions.fb());
console.info(window.getFunctions.fc());
console.info(window.getFunctions.fa());
console.info(window.getFunctions.fd());
从上面的js中知道,有一个匿名函数,参数为window,在匿名函数内部把getFunctions()赋给了window的一个属性,这样getFunctions()就是公开的,那么怎样控制其他的函数公开还是私有呢?在getFunctions()内部我们返回了一个json对象,这个对象包含了两个方法,也就相当于把getFunctions()中的两个函数公开了。
上一篇:JSON