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

桂林有名网站制作公司兰州建设网站的公司

桂林有名网站制作公司,兰州建设网站的公司,关于网站开发的文档,爱站网的关键词是怎么来的定义: 一个函数能够访问其它函数内部定义的变量 形成的原理: (1)函数创建:在一个函数(外部函数)中定义另一个函数(内部函数)。 (2)内部函数访问:内部函数可以访问和修改外部函数中的局部变量。 (3)函数…

定义:

一个函数能够访问其它函数内部定义的变量

形成的原理:

(1)函数创建:在一个函数(外部函数)中定义另一个函数(内部函数)。

(2)内部函数访问:内部函数可以访问和修改外部函数中的局部变量。

(3)函数执行:外部函数执行并返回内部函数时,外部函数的作用域(包括其中的变量)不会被销毁,因为内部函数依然持有对这些变量的引用。

使用场景:

(1)回调函数

闭包可以用作回调函数,在异步操作完成后执行。

function fetchData(callback) {setTimeout(() => {let data = 'Some data';callback(data);}, 1000);
}fetchData((result) => {console.log(result); // 输出: Some data
});

(2)定时器传参

闭包可以在定时器中使用,以传递和维护参数。

function startTimer(seconds) {setTimeout(() => {console.log(`Time's up! ${seconds} seconds elapsed.`);}, seconds * 1000);}startTimer(5); // 输出: Time's up! 5 seconds elapsed.

(3)防抖和节流

防抖和节流函数使用闭包来缓存状态和实现优化。

防抖:在事件停止触发后才执行函数。

function debounce(func, delay) {let timer;return function(...args) {clearTimeout(timer);timer = setTimeout(() => func.apply(this, args), delay);};
}const handleResize = debounce(() => {console.log('Resize event handled!');
}, 300);window.addEventListener('resize', handleResize);

节流:限制函数的执行频率。

function throttle(func, limit) {let lastFunc;let lastRan;return function(...args) {if (!lastRan) {func.apply(this, args);lastRan = Date.now();} else {clearTimeout(lastFunc);lastFunc = setTimeout(() => {if (Date.now() - lastRan >= limit) {func.apply(this, args);lastRan = Date.now();}}, limit - (Date.now() - lastRan));}};
}const handleScroll = throttle(() => {console.log('Scroll event handled!');
}, 1000);window.addEventListener('scroll', handleScroll);

(4)封装私有变量和函数

使用闭包来创建私有变量和函数。​​​​​​​

function createCounter() {let count = 0;return {increment: function() {count++;console.log(count);},decrement: function() {count--;console.log(count);}};
}const counter = createCounter();
counter.increment(); // 输出: 1
counter.increment(); // 输出: 2
 

(5)缓存

闭包可以用于实现简单的缓存机制。

function createCache() {let cache = {};return function(key, value) {if (value !== undefined) {cache[key] = value;}return cache[key];};
}const cache = createCache();
cache('name', 'John');
console.log(cache('name')); // 输出: John

(6)高阶函数

高阶函数是接受函数作为参数或返回函数的函数

function makeMultiplier(multiplier) {return function(value) {return value * multiplier;};
}const double = makeMultiplier(2);
console.log(double(5)); // 输出: 10

补充一个问题:闭包一定会造成内存泄露吗?

不一定,只有内部的函数保留到外部,在外部执行时才会造成内存泄露

以上是个人的一些理解,如有不足欢迎评论区留言,下期见~

http://www.sczhlp.com/news/133907/

相关文章:

  • 高校网站建设目的电子商务网站建设期末试卷答案
  • win7 做网站服务器开网站做网站赚钱吗
  • 中国建设人才信息网做seo前景怎么样
  • 国内做的好网站有哪些手工制作衣服童装环保
  • 网站怎么做充值系统青海城乡和住房建设厅网站
  • 企业建设网站意义网站和平台是一个意思吗
  • 帮别人备案网站自建网站餐饮服务提供者
  • 做网站公司松江小米网站的建设目的
  • 免费做试用的网站网站开发的开题报告模板
  • 设计室内装修app软件深圳优化网站公司
  • 医院可以做网站吗网站怎么做来流量吗
  • 电子商务网站建设和管理的意义天河做网站哪家好
  • 网站建设 英文怎么说天河微网站建设
  • 曲周专业做网站网站邮箱配置
  • wordpress页脚链接优化大师好用吗
  • php网站视频代码关键词全网搜索指数
  • 网站开发微信支付接入企业网站和展板建设
  • 东宁做木耳招工人网站建设官方网站查询
  • 网站制作及维护合同反网站搭建一条龙
  • 重庆建站广州微信网站设计
  • 哪个建站平台较好信贷员在哪个网站做推广
  • 常见的分类信息网站有哪些php做学校网站免费
  • 提供网站设计收费标准网站开发登录链接
  • 广州网站建设乐云seo模板中心网站建设 三牛
  • 考试报名费悦生活建设银行网站网站转移空间备案是不是就没有了
  • 平面设计免费模板网站信息网络系统
  • 网站用户体验分析怎么做广告设计公司名称推荐
  • wordpress网站设置关键词网站建设招标书
  • 广州南沙区建设局网站怎么制作婚介网站
  • 海南建设工程股份有限公司网站网站做用户登录