JavaScript代码执行的先后顺序问题


Posted in Javascript onOctober 29, 2017

一、js--->单线程

 

严格意义上来说,javascript没有多线程的概念,所有的程序都是单线程依次执行的。

  1、什么是单线程?

通俗点说,就是代码在执行过程中,另一段代码想要执行就必须等当前代码执行完成后才可以进行。我们拿一段代码来解释一下吧

for(var i=1;i<=3;i++){
   setTimeout(function(){
     console.log(i); //输出:4,4,4
   },0)
 }

我们来看一下上面的这段代码,既然延时器时间设置为0,那么应该执行一遍循环就应该立即打印出一个i,但是最终的打印结果为:4,4,4。之所以会出现上面的结果,正是因为js代码是单线程应用。

在执行过程中,先遇到for循环,for循环先进入线程。当i=1时,循环走到setTimeOut后,此时的for循环还没有执行完成,setTimeOut就会被放入一个地方(线程池)等待执行。此时for循环继续执行,当i=2时,for循环仍没有执行完,这时的setTimeOut仍会被放在线程池中等待执行……依次类推,直到for循环转完3遍后,for循环执行完了,此时线程空闲了,在线程池中等待执行的setTimeOut依次执行打印i,而for循环执行完成后,i变成了4,所以打印出了三个4。

2、如果想要改变上面的状况可以运用以下代码

//将var变为let
for(let i=1; i<=3; i++){
  setTimeOut(function(){
    console.log(i); //输出的结果为1,2,3
  },0);
}
//用自执行函数进行包裹
for(var i=1; i<=3; i++){
  !function(i){
    setTimeOut(function(){
      console.log(i); //输出的结果为1,2,3
    },0);
  }(i)
}

二、js中的函数作用域和代码的执行

>>>函数作用域

我们先来了解一下以下几个概念:

1、在js语言中,没有类似于c语言这样的块级作用域。

2、js语言中的顶级作用域为window对象范围内,称为全局作用域,在全局作用域中声明的变量为全局变量。

3、js函数范围内的变量只能在函数内部使用,函数外部无法使用,这样的变量为局部变量。

4、js函数可以嵌套,多个函数的嵌套构成了作用域的层层嵌套,这称为js中的作用域链。

5、js作用域链变量访问规则:

(1)、当前作用域内存在要访问的变量时,则使用当前作用域中的变量。

 

    (2)、当前作用域中不存在要访问的变量时,则会到上一层作用域中寻找,直到全局作用域。

>>>执行顺序

 

js代码执行分为两个部分:

1、代码的检查装载阶段(预编译阶段),此阶段进行变量和函数的声明,但是不对变量进行赋值,变量的默认值为undefined。

2、代码的执行阶段,此阶段对变量进行赋值和函数的声明。

看了上面的一些具体的概念,我们拿一段代码进行举例说明:

var a=1; //声明了一个全局变量
function func(){
  console.log(a); //输出:undefined。打印a,而在func这个作用域中已经声明了a变量,按照js的执行顺序,此时的a并未被赋值。
  var a=1;
  console.log(a); //输出:1。
}
func();

看上面的代码:第一个a输出undefined。原因:js作用域链的访问规则,当前作用域内存在要访问的变量a,所以使用当前作用域中的变量。再根据js代码的执行顺序,此时的a只是声明了而并未被赋值,默认为undefined,所以输出undefined。

而第二个a,输出1,正是因为此时的a已经被声明且被赋值,所以a输出1。

总结

以上所述是小编给大家介绍的JavaScript代码执行的先后顺序问题,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
JScript中的undefined和&quot;undefined&quot;的区别
Mar 08 Javascript
腾讯UED 漂亮的提示信息效果代码
Sep 12 Javascript
JQUERY 实现窗口滚动搜索框停靠效果(类似滚动停靠)
Mar 27 Javascript
为jquery的ajaxfileupload增加附加参数的方法
Mar 04 Javascript
理解javascript异步编程
Jan 27 Javascript
jquery 手势密码插件
Mar 17 Javascript
react-native DatePicker日期选择组件的实现代码
Sep 12 Javascript
vue router自动判断左右翻页转场动画效果
Oct 10 Javascript
Echarts地图添加引导线效果(labelLine)
Sep 30 Javascript
微信小程序实现录制、试听、上传音频功能(带波形图)
Feb 27 Javascript
js的Object.assign用法示例分析
Mar 05 Javascript
vant自定义二级菜单操作
Nov 02 Javascript
springmvc接收jquery提交的数组数据代码分享
Oct 28 #jQuery
ES6中Class类的静态方法实例小结
Oct 28 #Javascript
jQuery实现的简单前端搜索功能示例
Oct 28 #jQuery
jQuery实现点击下拉框中的值累加到文本框中的方法示例
Oct 28 #jQuery
jquery ajax异步提交表单数据的方法
Oct 27 #jQuery
mint-ui的search组件在键盘显示搜索按钮的实现方法
Oct 27 #Javascript
基于BootStrap的文本编辑器组件Summernote
Oct 27 #Javascript
You might like
PHP教程 预定义变量
2009/10/23 PHP
解析thinkphp基本配置 convention.php
2013/06/18 PHP
解析php file_exists无效的解决办法
2013/06/26 PHP
PHP计算2点经纬度之间的距离代码
2013/08/12 PHP
PHP实时统计中文字数和区别
2019/02/28 PHP
JavaScript获取GridView中用户点击控件的行号,列号
2009/04/14 Javascript
javascript下arguments,caller,callee,call,apply示例及理解
2009/12/24 Javascript
jquery.validate使用攻略 第五步 正则验证
2010/07/01 Javascript
JS高级拖动技术 setCapture,releaseCapture
2011/07/31 Javascript
从零学jquery之如何使用回调函数
2014/05/16 Javascript
node.js中的path.sep方法使用说明
2014/12/08 Javascript
js数组去重的5种算法实现
2015/11/04 Javascript
JS获取input file绝对路径的方法(推荐)
2016/08/02 Javascript
解决ajax不能访问本地文件问题(利用js跨域原理)
2017/01/24 Javascript
jQuery在header中设置请求信息的方法
2017/03/06 Javascript
关于vue.js v-bind 的一些理解和思考
2017/06/06 Javascript
浅谈angular4 ng-content 中隐藏的内容
2017/08/18 Javascript
如何使用Node.js爬取任意网页资源并输出PDF文件到本地
2019/06/17 Javascript
[01:11:10]2014 DOTA2华西杯精英邀请赛 5 24 iG VS VG加赛
2014/05/26 DOTA
[03:37]2014DOTA2国际邀请赛 主赛事第一日胜者组TOPPLAY
2014/07/19 DOTA
[05:40]DOTA2荣耀之路6:Wings最后进攻
2018/05/30 DOTA
Python多线程编程(六):可重入锁RLock
2015/04/05 Python
机器学习python实战之决策树
2017/11/01 Python
浅谈Django中的数据库模型类-models.py(一对一的关系)
2018/05/30 Python
使用numpy和PIL进行简单的图像处理方法
2018/07/02 Python
python代码实现逻辑回归logistic原理
2019/08/07 Python
python字典按照value排序方法
2020/12/28 Python
Brother加拿大官网:打印机、贴标机、缝纫机
2019/10/09 全球购物
旅游与酒店管理专业求职信
2014/07/21 职场文书
在校大学生自我评价范文
2014/09/12 职场文书
领导干部个人对照检查材料(群众路线)
2014/09/26 职场文书
后进基层党组织整改方案
2014/10/25 职场文书
2014年结对帮扶工作总结
2014/12/17 职场文书
2015年公共机构节能宣传周活动总结
2015/03/26 职场文书
原生JS实现分页
2022/04/19 Javascript
Java中Dijkstra(迪杰斯特拉)算法
2022/05/20 Java/Android