原帖地址: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`,为网页开发者提供了强大的交互设计工具,使他们能够构建更丰富、更具有吸引力的用户体验。通过熟练掌握这类框架,开发者可以创建更加灵活和个性化的弹出对话框,提高用户...
【标签】虽为空,但我们可以推断出一些关键标签,如:“毕业设计”、“整站程序”、“网络学院”、“PHP”(因为通常使用PHP进行网页开发)、“MySQL”(常用于数据库存储)和“前端技术”(HTML、CSS、JavaScript等...
### JavaScript 实现弹出小窗口知识点详解 #### 标题:JavaScript 实现弹出小窗口 - **核心概念**:本篇文章主要介绍了如何利用 JavaScript 的 `window.open()` 方法来实现弹出新窗口的功能。 #### 描述:...
在网页中,我们经常需要与用户进行交互,比如显示提示信息、获取用户输入等,这时候JavaScript的弹出对话框功能就显得尤为重要。本文将深入探讨"Javascript点击弹出对话框"这一主题,以及如何在实际应用中实现类似...
JavaScript弹出层是一种常见的网页交互元素,用于在用户与页面交互时显示额外的信息或功能,如警告、确认对话框、模态窗口等。在网页设计和开发中,掌握JavaScript弹出层的创建和操作技巧是至关重要的。下面将详细...
JavaScript,作为全球最广泛使用的客户端脚本语言,是构建现代Web应用的核心技术之一。对于求职者来说,掌握JavaScript面试题并理解其背后的原理是至关重要的。以下是一些常见的JavaScript面试题,以及它们所涵盖的...
下面将详细介绍如何使用js-javascript来实现div层的弹出效果。 首先,我们要明白JavaScript(简称JS)是一种轻量级的解释型编程语言,常用于网页和网络应用的客户端脚本。在网页中,JS可以操作DOM(文档对象模型)...
在网页设计中,"JavaScript弹出遮盖层"是一个常见且实用的技术,用于创建对话框、提示框或者加载指示器等效果,提供更好的用户体验。 首先,我们需要了解遮盖层(Overlay)的概念。遮盖层是在网页上覆盖一层半透明...
"jspm"可能指的是JavaScript包管理器,它在前端部分用于管理和组织JavaScript库和模块。而"网上电子书店"则明确了项目的目标,即创建一个在线的图书销售平台。 在项目中,我们能看到两个重要的文件夹:“??java?-...
项目名称:彤筹网 - 基于SSM框架的完整项目源码 技术栈: - 主要语言:Java - 相关技术:CSS, JavaScript 项目概述: - 文件数量:共192个 - 文件类型: - XML配置文件:22个 - Java源代码文件:22个 - 图片...
项目名称:多功能SSM框架权限管理系统源码 技术栈: - 主要语言:JavaScript - 包含语言:JavaScript, CSS, HTML, Java, PHP 文件构成: - 总文件数:2350个 - JavaScript 文件:1024个 - CSS 文件:344个 - ...
精选JavaScript框架,库和软件的清单。 的开源代码库和课程表。 在家学习编码。 :vulcan_salute: Vue.js是一个渐进的,可逐步采用JavaScript框架,用于在Web上构建UI。 用于构建用户界面的声明性,高效且灵活...
【JavaScript经典特效——文字从右弹出】 在网页设计中,动态效果往往能吸引用户的注意力,提高用户体验。JavaScript作为一种客户端脚本语言,被广泛用于实现各种网页交互效果,其中之一便是"文字从右弹出"的特效。...
项目名称:基于SSM框架的积分管理系统 技术栈: - 主要编程语言:Java - 辅助技术:JavaScript 文件构成: - 总文件数:442个 - Java类文件:150个 - 配置文件(XML):111个 - Java源代码文件:66个 - JAR...
项目名称:基于SSM框架的企业级CRM系统 技术栈: - 主要语言:Java - 其他涉及语言:JavaScript, HTML, CSS 文件构成: - 总文件数:241个 - Java文件:80个 - XML配置文件:69个 - JavaScript文件:20个 - ...
项目简介:基于Python的Flask框架开发的旅游Web应用,致力于为用户提供便捷的在线旅游服务体验。 技术栈: - 主要编程语言:Python - 辅助技术:JavaScript, HTML, CSS, PHP 文件构成: - 总文件数:450个 - ...
JavaScript弹出层效果是一种常见的网页交互设计,它允许在用户与网页交互时显示额外的信息或功能,而不会离开当前页面。这种技术广泛应用于提示、警告、登录框、模态对话框以及各种用户反馈形式。在本篇文章中,我们...
项目名称:Java SSM框架集成日志功能增强Demo 主要编程语言:Java 技术栈包含: - Java - JavaScript - CSS - HTML 文件概览: - 总计文件数:86个 - Java源文件:26个 - XML配置文件:16个 - JavaScript脚本...
在IT行业中,"点击按钮弹出窗口"是一个常见的交互设计技术,主要应用于...在Web开发中,前端框架如Bootstrap、Vue.js或React.js也提供了更便捷的方法来创建弹出窗口,这些框架通常封装了弹出框组件,简化了开发过程。