原帖地址: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...
【标签】虽为空,但我们可以推断出一些关键标签,如:“毕业设计”、“整站程序”、“网络学院”、“PHP”(因为通常使用PHP进行网页开发)、“MySQL”(常用于数据库存储)和“前端技术”(HTML、CSS、JavaScript等...
囍管家是我们与团队成员共同开发的婚礼管理平台,它基于Python的Django框架,致力于为用户提供一站式的婚礼筹备解决方案。该平台使用了前沿的前端技术,如JavaScript、CSS和HTML,确保了用户体验的流畅与界面设计的...
本篇文章将详细介绍一款名为"dialogs"的jQuery弹出层框架,该框架以其方便性和美观性,深受开发者喜爱。 dialogs框架是一款基于jQuery的轻量级弹出层插件,它通过简单的API调用即可快速创建各种类型的弹出层效果。...
在网页中,我们经常需要与用户进行交互,比如显示提示信息、获取用户输入等,这时候JavaScript的弹出对话框功能就显得尤为重要。本文将深入探讨"Javascript点击弹出对话框"这一主题,以及如何在实际应用中实现类似...
JavaScript弹出层是一种常见的网页交互元素,用于在用户与页面交互时显示额外的信息或功能,如警告、确认对话框、模态窗口等。在网页设计和开发中,掌握JavaScript弹出层的创建和操作技巧是至关重要的。下面将详细...
中文名: JavaScript权威指南 (第6版) 原名: JavaScript: The Definitive Guide: Activate Your Web Pages, 6th edition 作者: David Flanagan 版本: 英文文字版-pdf/EPUB + 完整书中源代码 出版社: O'Reilly 书号: ...
JavaScript,作为全球最广泛使用的客户端脚本语言,是构建现代Web应用的核心技术之一。对于求职者来说,掌握JavaScript面试题并理解其背后的原理是至关重要的。以下是一些常见的JavaScript面试题,以及它们所涵盖的...
JavaScript弹出层表单提交是一种常见的用户交互设计,它允许用户在不离开当前页面的情况下填写并提交表单数据。这种技术常用于网站的登录、注册、评论或编辑功能,提供了良好的用户体验,因为用户无需跳转到新页面...
本文将详述一些与.NET相关的面试题目,涵盖了C#、SQL、ADO.NET、JavaScript以及AJAX等技术领域。这些题目旨在检验面试者的基础知识、编程能力以及解决实际问题的能力。 1、C#技术问答题: - 什么是命名空间?如何...
"jspm"可能指的是JavaScript包管理器,它在前端部分用于管理和组织JavaScript库和模块。而"网上电子书店"则明确了项目的目标,即创建一个在线的图书销售平台。 在项目中,我们能看到两个重要的文件夹:“??java?-...
【标签】为空,意味着没有预定义的特定技术关键词,但我们可以通过标题和描述推测出一些关键点,例如Java开发、企业级应用、设备点检管理等。 【压缩包子文件的文件名称列表】包含以下文件: 1. ??java?-139-net???...
项目名称:彤筹网 - 基于SSM框架的完整项目源码 技术栈: - 主要语言:Java - 相关技术:CSS, JavaScript 项目概述: - 文件数量:共192个 - 文件类型: - XML配置文件:22个 - Java源代码文件:22个 - 图片...
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作为一种客户端脚本语言,被广泛用于实现各种网页交互效果,其中之一便是"文字从右弹出"的特效。...