JS ES6中setTimeout函数的执行上下文示例

发布时间 - 2026-01-11 00:51:56    点击率:

本文介绍的是setTimeout函数,延迟执行函数里的执行上下文,分享给大家供大家参考学习,来看看详细的内容:

(1)ES5中,setTimeout里面的函数的执行上下文为全局上下文,举例来说:

function log(){
 setTimeout(function(){console.log(this.id)},100)
}
var id=42
log.call({id:21})

//输出的结果为42

我们可以看到setTimeout,被延迟执行的函数,里面的this,指向的是全局作用域,也就是这个函数的上下文为全局上下文。

(2)在ES6的箭头函数中,setTimeout里面,如果执行了一个箭头函数,那么这个函数的执行上下文为定义这个箭头函数所在的函数。

function log(){
 setTimeout(()=>{
  console.log(this.id)
 },100)
}
var id=42;
log.call({id:21})

//这次输出的是21

总结:

因为ES6中,箭头函数的this,规定的指向定义这个箭头函数所在的那个函数。于是这里箭头函数里面的this,就固定bind了{id:21}。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


# es6  # settimeout  # es6的settimeout  # 执行函数  # js bind 函数 使用闭包保存执行上下文  # 深入理解JavaScript 中的执行上下文和执行栈  # 一篇文章弄懂javascript中的执行栈与执行上下文  # JavaScript ECMA-262-3 深入解析(一):执行上下文实例分析  # 通过实例了解JS执行上下文运行原理  # Javascript执行上下文顺序的深入讲解  # js 执行上下文和作用域的相关总结  # 详解JavaScript中的执行上下文及调用堆栈  # 深入学习JavaScript执行上下文  # 的是  # 好了  # 举例来说  # 给大家  # 可以看到  # 来看看  # 这篇文章  # 谢谢大家  # 有疑问  # brush  # class  # function  # js  # pre 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康  大连 网站制作,大连天途有线官网?  Swift中swift中的switch 语句  佛山网站制作系统,佛山企业变更地址网上办理步骤?  北京的网站制作公司有哪些,哪个视频网站最好?  HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】  php增删改查怎么学_零基础入门php数据库操作必知基础【教程】  php485函数参数是什么意思_php485各参数详细说明【介绍】  如何在建站宝盒中设置产品搜索功能?  laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法  Laravel如何使用Sanctum进行API认证?(SPA实战)  如何安全更换建站之星模板并保留数据?  实例解析angularjs的filter过滤器  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  Laravel Octane如何提升性能_使用Laravel Octane加速你的应用  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  javascript读取文本节点方法小结  黑客如何利用漏洞与弱口令入侵网站服务器?  JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)  UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】  浅析上传头像示例及其注意事项  javascript中数组(Array)对象和字符串(String)对象的常用方法总结  Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案  如何用JavaScript实现文本编辑器_光标和选区怎么处理  详解Android——蓝牙技术 带你实现终端间数据传输  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】  Swift中switch语句区间和元组模式匹配  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  ,在苏州找工作,上哪个网站比较好?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  如何在阿里云ECS服务器部署织梦CMS网站?  HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】  Android仿QQ列表左滑删除操作  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  Laravel怎么防止CSRF攻击_Laravel CSRF保护中间件原理与实践  香港服务器网站卡顿?如何解决网络延迟与负载问题?  小米17系列还有一款新机?主打6.9英寸大直屏和旗舰级影像  长沙企业网站制作哪家好,长沙水业集团官方网站?  如何确保FTP站点访问权限与数据传输安全?  什么是JavaScript解构赋值_解构赋值有哪些实用技巧  Laravel如何编写单元测试和功能测试?(PHPUnit示例)  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  大学网站设计制作软件有哪些,如何将网站制作成自己app?  Laravel Fortify是什么,和Jetstream有什么关系  简单实现Android验证码  Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率