原帖地址:http://www.cnblogs.com/happyframework/p/3160254.html
背景
经常需要向新入职的年轻同学解释Javascript的两个概念:单线程和作用域链,今天就再写篇博客说明一下。
单线程
- 队列:只有一个用来存储回调方法的队列。
- 消费线程:只有一个消费线程,不停的从队列中取方法,然后进行调用。这也是为什么Javascript称作为单线程的原因。
- 生产线程:有多个生产线程,不同的向队列中插入方法,常见的生成线程有:定时器、Ajax和浏览器事件。这也是为什么Javascript称作为事件驱动的原因。
参考文章:http://www.cnblogs.com/happyframework/archive/2013/04/23/3035596.html。
作用域链条
局部变量不是存储在“栈”中的,不要试着用传统的“栈”式作用域来理解。
参考文章:http://www.cnblogs.com/happyframework/archive/2013/04/22/3034087.html。
示例
1 function sleep(millisecond){
2 var start = new Date();
3 while(new Date().getTime() - start.getTime() <= millisecond) {}
4 }
5
6 var a = 6;
7 setTimeout(function () {
8 alert(a);
9 a = 666;
10 }, 0);
11 sleep(5000);
12 a = 66;
这个例子的执行过程向队列里插入了2快代码:
第一块:sleep定义、局部变量a定义和赋值、setTimeout方法调用、sleep方法调用和a赋值。
第二块:setTimeout的第二个参数(匿名函数)的调用。
根据这个可以知道,匿名函数的执行是在a = 66之后执行的,结合作用域链的知识,可以知道弹出的结果是66。
备注
写的还不够清晰,基本上是QQ里聊天的内容,有些概念是我在网上找的,没有看Javascript规范,所以大家要慎重理解。
本文链接:http://www.cnblogs.com/happyframework/p/3160254.html,转载请注明。
分享到:
相关推荐
JavaScript弹出框架,特别是`lhgdialog`,为网页开发者提供了强大的交互设计工具,使他们能够构建更丰富、更具有吸引力的用户体验。通过熟练掌握这类框架,开发者可以创建更加灵活和个性化的弹出对话框,提高用户...
这是一个基于Java技术开发的五台山景点购票系统源代码项目,主要使用了Spring、SpringMVC和MyBatis(SSM)三大框架进行构建。该项目的源代码组织结构清晰,便于理解和学习。以下是对各部分的详细解释: 1. **Spring...
在网页中,我们经常需要与用户进行交互,比如显示提示信息、获取用户输入等,这时候JavaScript的弹出对话框功能就显得尤为重要。本文将深入探讨"Javascript点击弹出对话框"这一主题,以及如何在实际应用中实现类似...
JavaScript弹出层是一种常见的网页交互元素,用于在用户与页面交互时显示额外的信息或功能,如警告、确认对话框、模态窗口等。在网页设计和开发中,掌握JavaScript弹出层的创建和操作技巧是至关重要的。下面将详细...
中文名: JavaScript权威指南 (第6版) 原名: JavaScript: The Definitive Guide: Activate Your Web Pages, 6th edition 作者: David Flanagan 版本: 英文文字版-pdf/EPUB + 完整书中源代码 出版社: O'Reilly 书号: ...
开发者可能使用了Spring Boot或Spring MVC等框架来构建这个服务,因为“ssm”(Spring、SpringMVC、MyBatis的缩写)在文件名中出现,这暗示了后端使用了这些技术。 "??java?-104-202202059. ???!--MHK???????-??\...
JavaScript,作为全球最广泛使用的客户端脚本语言,是构建现代Web应用的核心技术之一。对于求职者来说,掌握JavaScript面试题并理解其背后的原理是至关重要的。以下是一些常见的JavaScript面试题,以及它们所涵盖的...
本文将详述一些与.NET相关的面试题目,涵盖了C#、SQL、ADO.NET、JavaScript以及AJAX等技术领域。这些题目旨在检验面试者的基础知识、编程能力以及解决实际问题的能力。 1、C#技术问答题: - 什么是命名空间?如何...
"jspm"可能指的是JavaScript包管理器,它在前端部分用于管理和组织JavaScript库和模块。而"网上电子书店"则明确了项目的目标,即创建一个在线的图书销售平台。 在项目中,我们能看到两个重要的文件夹:“??java?-...
【标签】为空,意味着没有预定义的特定技术关键词,但我们可以通过标题和描述推测出一些关键点,例如Java开发、企业级应用、设备点检管理等。 【压缩包子文件的文件名称列表】包含以下文件: 1. ??java?-139-net???...
2. **Spring框架**:Spring是一个全面的开发框架,它支持依赖注入、事务管理、安全控制以及AOP(面向切面编程)。在游泳馆管理系统中,Spring可能用于处理业务逻辑和数据库操作。 3. **Hibernate或MyBatis**:这些是...
项目名称:多功能SSM框架权限管理系统源码 技术栈: - 主要语言:JavaScript - 包含语言:JavaScript, CSS, HTML, Java, PHP 文件构成: - 总文件数:2350个 - JavaScript 文件:1024个 - CSS 文件:344个 - ...
精选JavaScript框架,库和软件的清单。 的开源代码库和课程表。 在家学习编码。 :vulcan_salute: Vue.js是一个渐进的,可逐步采用JavaScript框架,用于在Web上构建UI。 用于构建用户界面的声明性,高效且灵活...
标题中的“基于java的-25-[计算机毕业设计]基于SSM雁门关风景区宣传网站-源码.zip”表明这是一个关于计算机毕业设计的项目,它使用了Java编程语言,并且基于Spring、Struts和MyBatis(简称SSM)框架构建了一个雁门关...
项目标题:基于SSM框架的企业工资管理系统源码 技术概述: - 主要编程语言:JavaScript - 综合技术栈:JavaScript, Java, CSS - 文件构成:总计268个文件,包括以下类型: - GIF预览图:75个 - JavaScript文件:...
【JavaScript经典特效——文字从右弹出】 在网页设计中,动态效果往往能吸引用户的注意力,提高用户体验。JavaScript作为一种客户端脚本语言,被广泛用于实现各种网页交互效果,其中之一便是"文字从右弹出"的特效。...
项目名称:基于SSM框架的积分管理系统 技术栈: - 主要编程语言:Java - 辅助技术:JavaScript 文件构成: - 总文件数:442个 - Java类文件:150个 - 配置文件(XML):111个 - Java源代码文件:66个 - JAR...
项目简介:基于Python的Flask框架开发的旅游Web应用,致力于为用户提供便捷的在线旅游服务体验。 技术栈: - 主要编程语言:Python - 辅助技术:JavaScript, HTML, CSS, PHP 文件构成: - 总文件数:450个 - ...
【标签】为空,意味着没有特定的技术标签来指导我们理解项目的具体技术栈。通常,这样的项目可能会涉及以下技术: 1. **Java**:这是一种广泛使用的面向对象的编程语言,尤其适用于企业级应用和Web服务开发。在这个...
"框架集弹出框"这个主题,可能指的是在框架集中使用JavaScript或者jQuery来实现类似于弹出对话框的效果。 首先,让我们来了解`frameset`标签。在HTML中,`<frameset>`元素用于定义页面的框架布局。通过使用`<frame>...