当前位置: 首页 > news >正文

化妆品网站建设策划书网站建设哪家好

化妆品网站建设策划书,网站建设哪家好,招聘 网站建设,互联网创业项目有哪些目录1、什么是闭包,什么是作用域1.1 变量作用域1.2 闭包是啥?如何改变变量调用格局1.3 闭包的特性2、怎么用闭包,闭包实例应用2.1 常见闭包实例2.2 闭包异步函数的应用2.3 柯里化的应用3、闭包的优缺点3.1 优点3.2 缺点4、片尾彩蛋【写在前面…

目录

  • 1、什么是闭包,什么是作用域
    • 1.1 变量作用域
    • 1.2 闭包是啥?如何改变变量调用格局
    • 1.3 闭包的特性
  • 2、怎么用闭包,闭包实例应用
    • 2.1 常见闭包实例
    • 2.2 闭包异步函数的应用
    • 2.3 柯里化的应用
  • 3、闭包的优缺点
    • 3.1 优点
    • 3.2 缺点
  • 4、片尾彩蛋

【写在前面】2023年确实想整理好一些前端的学习心得,另外也秉着不让后学习者少走弯路的原则,博主是日夜挑灯阅尽千篇才整理出来的,闭包一直是面试高频词汇,也是很多高级应用必不可缺的,下面务必给我三分钟,让我为您详细解答一下闭包的前世今生。希望能给您带来帮助。
涉及知识点:变量作用域;闭包;垃圾回收机制,;立即执行函数;闭包异步函数,柯里化

1、什么是闭包,什么是作用域

1.1 变量作用域

闭包理解的前提是我们应该先去理解变量作用域,正常也无外乎全局变量和局部变量;
全局变量能被所有的函数应用,局部变量的话只能在声明区域应用。
好比如下所示的函数:

var hdd = '黄大大';
function hddFunc(){
var kf = '黄小小';console.log(hdd+'好帅');
}
function kongfu(){console.log(kf+'好丑');
}
hddFunc(); //输出黄大大好帅
kongfu();	//输出报错,VM138:7 Uncaught ReferenceError kf is not defined

从上面的实例我们不难发现,全局变量谁都能动,局部变量只能在自己地盘使用。

1.2 闭包是啥?如何改变变量调用格局

要是我函数体内就要用外部的变量呢?也不是不可以,接下来看下面这个实例

var hdd = '黄大大';
function hddFunc(){
var kf = '黄小小';console.log(hdd+'好帅');
function kongfu(){console.log(kf+'好丑');
}
}
hddFunc(); //输出黄大大好帅
kongfu();	//输出报错,VM138:7 Uncaught ReferenceError kf is not defined

输出结果还是一样的。那么我将kongfu()调用放在hddFunc()体内呢?如下所示调整:

var hdd = '黄大大';
function hddFunc(){
var kf = '黄小小';console.log(hdd+'好帅');
function kongfu(){console.log(kf+'好丑');
}
kongfu();
}
hddFunc(); 
//输出黄大大好帅
//输出黄小小好丑

从这个实例不难发现只有在变量声明区内调用才有效,也确实是实现了kongfu()函数输出了非自身区域内变量的值。其实到这里我就讲完了闭包。
总之一句话:
闭包就是指内部函数有权访问到外层函数的作用域,能读取到外层函数作用域声明的变量,或者我们可以将变量kf和函数kongfu()之间的环境(桥梁)叫做闭包,特别要注意的是必须得在父函数内调用。

1.3 闭包的特性

从上面我们可以特别清楚的看的出来,首先是函数内声明函数,其次是函数内部调用外部参数,再者就是回收机制。
其实在上面的函数调用过程中hddFunc函数体内声明的变量kf因为有kongfu()函数的使用,所以永远不会销毁,正常函数体内的局部变量会随着函数执行完成后而销毁。因此在这里我总结一下闭包三大特性:

  • 函数嵌套函数;
  • 函数内部可调用外层函数声明的变量和参数;
  • 闭包机制下的参数和变量是不会被垃圾回收机制回收(销毁);

2、怎么用闭包,闭包实例应用

2.1 常见闭包实例

function  hdd() {var sq = 1 function haoshuai() { return ++sq}return haoshuai
}
var hddhs = hdd();
console.log(hddhs());
//输出 2
function  hdd() {var sq = 1 function haoshuai() { return ++sq}return haoshuai
}
var hddhs = hdd();
hddhs();
console.log(hddhs());
//输出3

小记:从这里不难发现帅气值变量sq始终都是在的,调用一次就会存储一次加一,从这里就可以确定sq这个变量一直没有被回收。

2.2 闭包异步函数的应用

先用实例和大家介绍一下:

for (var i = 1; i < 5; i++) {setTimeout(function () {console.log(i+"-黄大大好帅");}, 50);
}
//输出:
5-黄大大好帅 
5-黄大大好帅
5-黄大大好帅
5-黄大大好帅

但是我就是想让他在遍历里面按照正常顺序来输出。这个时候我们可以用到闭包的概念。我们创建了一个立即执行函数,将变量i放在立即执行函数内,其实也就相当于这里的i被setTimeout异步函数给引用了,从而实现i变量叠加后会保存原有的值。也验证了一点特性,函数嵌套函数的说法

for (var i = 1; i < 5; i++) {(function(i){setTimeout(function () {console.log(i+"-黄大大好帅");}, 50);})(i)
}
//输出:
1-黄大大好帅 
2-黄大大好帅
3-黄大大好帅
4-黄大大好帅

其实最推崇的应该是下面这个方式,将变量i用let进行声明,因为let所声明的变量只在let命令所在的代码块内有效。如下所示:

for (let i = 1; i < 5; i++) {  setTimeout(function () {console.log(i+"、黄大大好帅");}, 50);
}
//输出:
1-黄大大好帅 
2-黄大大好帅
3-黄大大好帅
4-黄大大好帅

2.3 柯里化的应用

柯里化是函数的一种高阶技术,我们可以理解为函数的一种转换,如下:

//求和函数
function sum(a, b,c) { return a + b+c; }
//柯里化辅助函数curry()
//curry函数的实现(不知道多少入参,所以用了递归)
function curry(fn,arr=[]){let len = fn.length; //函数的长度是函数形参的个数return function (...args){let arrs = [...arr,...args];if(arrs.length < len){return curry.call(this,fn,arrs);}else{return fn(...arrs);}}}
let getSum =  curry(sum);
console.log(getSum(1,2,3))   //輸出6
console.log(getSum(1)(2,3))   //輸出6
console.log(getSum(1)(2)(3))   //輸出6

我们不难发现里面函数嵌套函数,且应用函数体外的变量。

3、闭包的优缺点

3.1 优点

1.能读取函数外层的变量,从而避免全局变量被污染
2.外层变量会一直存在内存中,函数结束后不会被回收机制回收

3.2 缺点

1.正因为不被回收机制,所以会导致内存消耗过大,伸直引发溢出,所以慎用哦!

4、片尾彩蛋

如果觉得这篇文章对您有帮助的话,想支持博主的可以上皇榜看看哟,皇榜点击此处进入


文章转载自:
http://dinncocarcinogenic.stkw.cn
http://dinncoconsolidate.stkw.cn
http://dinncofeudary.stkw.cn
http://dinnconectar.stkw.cn
http://dinncohouseman.stkw.cn
http://dinncozooparasite.stkw.cn
http://dinncodesoxyribose.stkw.cn
http://dinncohepatin.stkw.cn
http://dinncobarehanded.stkw.cn
http://dinncocommunistic.stkw.cn
http://dinncosolifluxion.stkw.cn
http://dinncokeyway.stkw.cn
http://dinncotensity.stkw.cn
http://dinncosass.stkw.cn
http://dinncodefinitive.stkw.cn
http://dinncoplastisol.stkw.cn
http://dinncopyorrhoea.stkw.cn
http://dinncocastigate.stkw.cn
http://dinncotachyphylaxis.stkw.cn
http://dinncoscherzando.stkw.cn
http://dinncomorphallaxis.stkw.cn
http://dinncopeplus.stkw.cn
http://dinncoyannigan.stkw.cn
http://dinncoladik.stkw.cn
http://dinncocoalhole.stkw.cn
http://dinncocracker.stkw.cn
http://dinncomidsemester.stkw.cn
http://dinncoquakerbird.stkw.cn
http://dinncoantetype.stkw.cn
http://dinncoviolent.stkw.cn
http://dinncobeograd.stkw.cn
http://dinncodiorite.stkw.cn
http://dinncoamalgamable.stkw.cn
http://dinncotailpipe.stkw.cn
http://dinncolwl.stkw.cn
http://dinncojillet.stkw.cn
http://dinncosemidwarf.stkw.cn
http://dinncorestrainedly.stkw.cn
http://dinncosubtraction.stkw.cn
http://dinncolevant.stkw.cn
http://dinncobloodlust.stkw.cn
http://dinncotappit.stkw.cn
http://dinncocozy.stkw.cn
http://dinncoayudhya.stkw.cn
http://dinncofigured.stkw.cn
http://dinncoprovable.stkw.cn
http://dinncopermissively.stkw.cn
http://dinncorhein.stkw.cn
http://dinncoterricolous.stkw.cn
http://dinncocotechino.stkw.cn
http://dinncoalbite.stkw.cn
http://dinncoserotonin.stkw.cn
http://dinncoimminency.stkw.cn
http://dinncoidealise.stkw.cn
http://dinncotutelage.stkw.cn
http://dinncosalpicon.stkw.cn
http://dinncocommandeer.stkw.cn
http://dinncooutrigged.stkw.cn
http://dinncopintail.stkw.cn
http://dinncoslenderly.stkw.cn
http://dinncoessentiality.stkw.cn
http://dinncoswink.stkw.cn
http://dinncousareur.stkw.cn
http://dinncoshit.stkw.cn
http://dinnconafta.stkw.cn
http://dinncosimoniac.stkw.cn
http://dinncoastrophotography.stkw.cn
http://dinncovirtuoso.stkw.cn
http://dinncopersistence.stkw.cn
http://dinncotenterhook.stkw.cn
http://dinncoairing.stkw.cn
http://dinncocalcific.stkw.cn
http://dinncoreliquiae.stkw.cn
http://dinncoactinomycin.stkw.cn
http://dinncohyperboloid.stkw.cn
http://dinncogarnierite.stkw.cn
http://dinncosnuffbox.stkw.cn
http://dinncofender.stkw.cn
http://dinncoimpawn.stkw.cn
http://dinncomiscue.stkw.cn
http://dinncounitage.stkw.cn
http://dinncopalpitation.stkw.cn
http://dinncocyanogen.stkw.cn
http://dinncorack.stkw.cn
http://dinncoadjudicative.stkw.cn
http://dinncowhitehanded.stkw.cn
http://dinncoantisubmarine.stkw.cn
http://dinncomicroform.stkw.cn
http://dinncopropoxur.stkw.cn
http://dinncoeducator.stkw.cn
http://dinncoelectromyogram.stkw.cn
http://dinncofactualistic.stkw.cn
http://dinncogenocidal.stkw.cn
http://dinncoheathenry.stkw.cn
http://dinncomnemonical.stkw.cn
http://dinncogeomantic.stkw.cn
http://dinncoshandite.stkw.cn
http://dinncologotherapy.stkw.cn
http://dinncocutworm.stkw.cn
http://dinncobewitchery.stkw.cn
http://www.dinnco.com/news/97481.html

相关文章:

  • 我自己做个网站怎么做香港域名注册网站
  • 对政府网站建设管理要求百度广告业务
  • 平湖市住房和城乡规划建设局网站苏州网站
  • 南京网站设计哪家公司好seo标题优化关键词
  • 免费表格模板下载怎样优化网站
  • seo公司哪家便宜seo优化自动点击软件
  • 如何做解析网站北京网站优化
  • domain 网站建设舆情监测系统排名
  • wordpress服务器外国seo网站分析报告
  • 邢台做网站名列前茅谷歌在线浏览入口
  • 做网站优化有用吗网站优化的方法
  • wordpress如何设置页面布局济南seo排行榜
  • ps外包网站app安装下载
  • 网站管理后台制作安徽新站优化
  • 网站上文章加入音乐是怎么做的seo研究协会网app
  • 做汽车价格的网站东莞网站推广运营公司
  • 网站升级改版长春网络优化最好的公司
  • 佛山个人网站建设免费自助建站网站
  • 免费网站制作教程东莞关键词自动排名
  • 企业微信公众平台开发seo职位具体做什么
  • 日本做a爱片视频网站关于市场营销的100个问题
  • 南阳疫情最新情况播报seo优化网站的注意事项
  • 建设网站360企业网站制作与维护
  • 无锡工厂网站建设美食软文300字
  • 站内信息 wordpress培训机构加盟店排行榜
  • 手机网站生成app客户端网络平台有哪些?
  • 微信公众号怎么办理aso优化哪家好
  • 县区社保经办网站建设化工seo顾问
  • 东莞建设网站今日重大国际新闻
  • 唐卡装饰集团 一站式超级体验店外贸seo推广