理解js闭包10大使用场景,大厂面试官好自为之!,BAT面试&高级进阶

return name;

}

}

var fn1 = fn()//执行函数将返回值(callback函数)赋值给fn1,

function fn2(f){

//将函数作为参数传入

console.log(f());//执行函数,并输出

}

fn2(fn1)//执行输出fn2

用闭包返回一个函数,把此函数作为另一个函数的参数,在另一个函数里面执行这个函数,最终输出 hello

4.IIFE(自执行函数)

(function(){

var name=“hello”;

var fn1= function(){

return name;

}

//直接在自执行函数里面调用fn2,将fn1作为参数传入

fn2(fn1);

})()

function fn2(f){

//将函数作为参数传入

console.log(f());//执行函数,并输出

}

直接在自执行函数里面将封装的函数fn1传给fn2,作为参数调用同样可以获得结果 hello

5.循环赋值

//每秒执行1次,分别输出1-10

for(var i=1;i<=10;i++){

(function(j){

//j来接收

setTimeout(function(){

console.log(j);

},j*1000);

})(i)//i作为实参传入

}

如果不采用闭包的话,会有不一样的情况,可以看我自己 闭包 的文章。

6.getter和setter

function fn(){

var name=‘hello’

setName=function(n){

name = n;

}

getName=function(){

return name;

}

//将setName,getName作为对象的属性返回

return {

setName:setName,

getName:getName

}

}

var fn1 = fn();//返回对象,属性setName和getName是两个函数

console.log(fn1.getName());//getter

fn1.setName(‘world’);//setter修改闭包里面的name

console.log(fn1.getName());//getter

  第一次输出 hello 用setter以后再输出 world ,这样做可以封装成公共方法,防止不想暴露的属性和函数暴露在外部。

7.迭代器(执行一次函数往下取一个值)

var arr =[‘aa’,‘bb’,‘cc’];

function incre(arr){

var i=0;

return function(){

//这个函数每次被执行都返回数组arr中 i下标对应的元素

return arr[i++] || ‘数组值已经遍历完’;

}

}

var next = incre(arr);

console.log(next());//aa

console.log(next());//bb

console.log(next());//cc

console.log(next());//数组值已经遍历完

8.首次区分(相同的参数,函数不会重复执行)

var fn = (function(){

var arr=[];//用来缓存的数组

return function(val){

if(arr.indexOf(val)==-1){//缓存中没有则表示需要执行

arr.push(val);//将参数push到缓存数组中

console.log(‘函数被执行了’,arr);

//这里写想要执行的函数

}else{

console.log(‘此次函数不需要执行’);

}

console.log(‘函数调用完打印一下,方便查看已缓存的数组:’,arr);

}

})();

fn(10);

fn(10);

fn(1000);

fn(200);

fn(1000);

执行结果如下:

可以明显的看到首次执行的会被存起来,再次执行直接取。

9.缓存

//比如求和操作,如果没有缓存,每次调用都要重复计算,采用缓存已经执行过的去查找,查找到了就直接返回,不需要重新计算

var fn=(function(){

var cache={};//缓存对象

var calc=function(arr){//计算函数

var sum=0;

//求和

for(var i=0;i<arr.length;i++){

sum+=arr[i];

}

return sum;

}

return function(){

var args = Array.prototype.slice.call(arguments,0);//arguments转换成数组

var key=args.join(“,”);//将args用逗号连接成字符串

var result , tSum = cache[key];

if(tSum){//如果缓存有

console.log(‘从缓存中取:’,cache)//打印方便查看

result = tSum;

}else{

//重新计算,并存入缓存同时赋值给result

result = cache[key]=calc(args);

console.log(‘存入缓存:’,cache)//打印方便查看

}

return result;

}

})();

fn(1,2,3,4,5);

fn(1,2,3,4,5);

fn(1,2,3,4,5,6);

fn(1,2,3,4,5,8);

fn(1,2,3,4,5,6);

输出结果:

10.节流函数

节流函数的作用是在限定的时间内函数只执行一次,比如:

1.按钮提交(可以避免重复提交,当然不只这种方法,将按钮设置为不可用也可以)。

2.scroll、mousehover、mousemove等触发频率高的时候。

主要的原理就是在闭包内设置一个标记,在限定的时间内这个flag设置为true,函数再次点击则不让执行,setTimeout函数执行以后将flag设置为flase,就可以继续执行 。

test
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

今天的文章可谓是积蓄了我这几年来的应聘和面试经历总结出来的经验,干货满满呀!如果你能够一直坚持看到这儿,那么首先我还是十分佩服你的毅力的。不过光是看完而不去付出行动,或者直接进入你的收藏夹里吃灰,那么我写这篇文章就没多大意义了。所以看完之后,还是多多行动起来吧!

可以非常负责地说,如果你能够坚持把我上面列举的内容都一个不拉地看完并且全部消化为自己的知识的话,那么你就至少已经达到了中级开发工程师以上的水平,进入大厂技术这块是基本没有什么问题的了。

较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!**

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

今天的文章可谓是积蓄了我这几年来的应聘和面试经历总结出来的经验,干货满满呀!如果你能够一直坚持看到这儿,那么首先我还是十分佩服你的毅力的。不过光是看完而不去付出行动,或者直接进入你的收藏夹里吃灰,那么我写这篇文章就没多大意义了。所以看完之后,还是多多行动起来吧!

可以非常负责地说,如果你能够坚持把我上面列举的内容都一个不拉地看完并且全部消化为自己的知识的话,那么你就至少已经达到了中级开发工程师以上的水平,进入大厂技术这块是基本没有什么问题的了。

资料领取方式:戳这里前往免费领取

  • 10
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript闭包是指函数能够访问并操作它外部函数作用域中的变量的特性。闭包JavaScript中有许多典型应用场景,其中包括以下几个方面。 1. 封装私有变量和方法:通过闭包,可以将一些变量和方法封装在函数的作用域内,外部无法直接访问和修改。这样可以防止变量被意外修改,实现类似私有成员的功能。 2. 创建模块化代码:通过使用闭包,可以实现模块化的代码结构。将相关的变量和方法封装在闭包内,只暴露必要的接口给外部使用,隔离变量和方法的作用域,减少全局命名空间的污染。 3. 缓存变量:通过使用闭包,可以将一些需要长时间保存的变量存在函数内部,避免将变量保存在全局作用域中。这样可以有效减少内存占用,提高性能,特别是对于大数据量的操作。 4. 实现函数柯里化:柯里化是一种将使用多个参数的函数转换为一系列使用一个参数的函数的技术。通过使用闭包,可以将函数柯里化的过程进行封装,实现更加灵活和可复用的函数。 5. 解决作用域问题:由于JavaScript存在函数作用域和块级作用域的差异,导致一些变量无法在特定作用域中访问。通过使用闭包,可以更好地解决这些作用域问题,使变量在需要的时候被访问。 总的来说,闭包JavaScript中是一个非常强大和灵活的特性,可以应用于各种场景,包括封装私有变量和方法、创建模块化代码、缓存变量、实现函数柯里化等。在实际开发中,合理地运用闭包可以提高代码的可维护性、性能和可扩展性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值