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

网站设计制作音乐排行榜wordpress中文竖排

网站设计制作音乐排行榜,wordpress中文竖排,浙江网站建设外贸,犀牛云网站建设怎么样Js面试之作用域与闭包 作用域词法作用域动态作用域 闭包闭包使用场景封装私有变量模块化开发保持变量状态异步操作 注意事项 最近在整理一些前端面试中经常被问到的问题,分为vue相关、react相关、js相关、react相关等等专题,可持续关注后续内容&#xff…

Js面试之作用域与闭包

  • 作用域
    • 词法作用域
    • 动态作用域
  • 闭包
    • 闭包使用场景
      • 封装私有变量
      • 模块化开发
      • 保持变量状态
      • 异步操作
  • 注意事项

最近在整理一些前端面试中经常被问到的问题,分为vue相关、react相关、js相关、react相关等等专题,可持续关注后续内容,会不断进行整理~

作用域

作用域(scope)定义了程序中变量的可访问性和生命周期,在js中,作用域有两种主要的类型:词法作用域(Lexical Scope)和动态作用域(Dynamic Scope);

词法作用域

词法作用域又称静态作用域,是指作用域在代码编写阶段就确定的,与函数的定义位置有关。javascript使用词法作用域,函数的作用域在函数定义时就已经确定

var globalVariable = 'I am global'function outer() {var outerVariabl = 'I am outer'function inner() {var innerVariable = 'I am inner'console.log(innerVariable) // 可以访问innerVariableconsole.log(outerVariable) // 可以访问outerVariableconsole.log(globalVariable) // 可以访问globalVariable}inner();console.log(innerVariable) // Error: innerVariable is not defined
}outer()

动态作用域

动态作用域是在运行时根据调用链来确定的,与函数的调用位置有关。js不使用动态作用域,而是使用词法作用域

闭包

闭包(Closure)是指一个函数和其词法作用域的组合。当函数在词法作用域以外的地方被调用时,它仍然能够访问自己的词法作用域,形成了闭包。
或说

闭包(Closure)是指有权访问另一个函数作用域中变量的函数,即便是在外部函数执行完毕之后。

function outer() {var outerVariable = 'I am outer'function inner() {console.log(outerVariable) // 形成闭包,可以访问outerVariable}return inner
}var closureFunction = outer()
closureFunction() // 通过闭包访问outerVariable

闭包使用场景

封装私有变量

通过闭包,可以创建私有变量,只能通过闭包内部的函数访问,不会被外部直接访问到;

function counter() {var count = 0;return function() {count++;console.log(count);};
}var increment = counter();
increment(); // 输出 1
increment(); // 输出 2

模块化开发

使用闭包可以创建模块,将相关的功能封装到一个闭包中,避免全局污染

var module = (function() {var privateVariable = 'I am private';function privateFunction() {console.log('This is private')}return {publicVariable: 'I am public',publicFunction: function() {console.log('This is public')}}
})()console.log(module.publicVariable) // I am public
module.publicFunction() // This is public

保持变量状态

由于闭包可以访问外部函数的变量,所以可以保持状态

function createCounter() {var count = 0;return {increment: function() {count++;console.log(count)},reset: function() {count = 0;console.log('Count reset')}}
}var counter = createCounter();
counter.increment(); // 输出1
counter.increment(); // 输出2

异步操作

在异步回调中经常使用闭包来保存状态

function fetchData(url, callback) {var data = null;fetchDataFromServer(url, function(result)) {// 调用 fetchDataFromServer 函数从服务器异步获取数据,并传给datadata = result;callback();});return function() {// 使用闭包中的dataconsole.log(data);}
}var getData = fetchData('https://example.com/data', function() {console.log('Data received');
})// 在合适的时机调用getData()

注意事项

  • 潜在的内存泄漏问题:如果闭包中引用了大量变量,可能导致内存无法释放。
  • 滥用闭包可能导致性能问题,因为它们会占用更多内存
http://www.yayakq.cn/news/642843/

相关文章:

  • 深圳网站制作十年乐云seo品牌网络推广是做什么工作的
  • 做房地产行业的怎么做网站北京装饰公司排名
  • 免费网站建设培训班科技设计网站建设
  • 个人网站设计论文范文jsp网站 自动发送邮件
  • 开发技术网站开发技术江苏网站建设
  • cms建站系统免费电商初学者
  • 企业营销系统和网站建设小破站下载
  • WordPress如何设置站点名称vi品牌形象设计案例
  • 电商网站需要哪些备案wecenter整合Wordpress
  • 宣传页在线设计软件网站优化培训班
  • 哪个网站推广产品好附近电脑培训学校
  • 网站百度关键词seo排名优化公司微网站建设价格
  • 单页面网站怎么优化房地产开发资质需要什么条件
  • 西安网站 技术支持牛商网企业网站自己怎么做
  • 网站数据库如何备份石家庄网站设计
  • 分销网站制作条件客户管理软件有哪些
  • 云南网站seo外包海珠一站式网站建设
  • 中国空间站建造完成遵义做网站 0852t
  • 北京网站制作的公司做视频网站公司要怎么做
  • 在阿里云备案网站通过做网站需要数据储存么
  • 北京建站者公司软件的开发流程
  • 巩义网站建设报价app免费下载安装
  • 青岛网站建设排名vs2015网站开发实例
  • 南海建设局网站网站开发的形式有
  • 深圳联雅网站建设wordpress自动添加图片alt属性
  • 外贸网站建设海外推广淘宝网站小视频怎么做
  • 深圳比较好的建站公司衡阳网站推广排名
  • 手机网站制作软件下载郑州外贸网站建设公司排名
  • 襄阳网站建设制作费用注册新公司网上核名网站
  • 嘉兴市城乡规划建设局网站网络系统分类