JavaScript解析机制

JavaScript是一种解释型语言,按照<script>块儿来预编译和执行。

JavaScript解释器在预编译阶段,先预声明变量,再预声明函数。在执行阶段,进行变量赋值,和函数执行。

示例1:

预编译阶段,对于变量只进行预声明,并初始化值为undefined,在执行阶段才真正进行赋值。

 1 alert(variableA); //undefined
 2 var variableA = 2;
 3 alert(variableA); //2
 4
 5
 6 alert(funcA); //function funcA(){alert(‘I am funcA.‘)}
 7 funcA(); //I am funcA.
 8 function funcA(){
 9     alert(‘I am funcA.‘);
10 }

示例2:

预编译预条件无关!

 1 alert(variableA); //undefined
 2 alert(funcA); //function funcA(){alert(‘I am funcA.‘)}
 3 funcA(); //I am funcA
 4
 5 if(true){
 6     var variableA = 2;
 7
 8 }else{
 9     function funcA(){
10         alert(‘I am funcA.‘);
11     }
12 }
13 alert(variableA); //2

示例3:

JavaScript按照<script>代码块来预编译!

1 <script>
2     funcA(); //I am funcA too.
3     function funcA(){
4         alert(‘I am funcA.‘);
5     }
6     function funcA(){
7         alert(‘I am funcA too.‘);
8     }
9 </script>
 1 <script>
 2     funcA(); //I am funcA.
 3     function funcA() {
 4         alert(‘I am funcA.‘);
 5     }
 6 </script>
 7 <script>
 8     funcA(); //I am funcA too.
 9     function funcA() {
10         alert(‘I am funcA too.‘);
11     }
12 </script>

示例4:

先预声明变量,再预声明函数,因此,预编译阶段variableA函数覆盖了variableA变量。在执行阶段,variableA变量被赋值为2,

1 alert(variableA); //function variableA(){alert(‘I am variableA.‘)}
2 var variableA = 2;
3 function variableA(){
4     alert(‘I am variableA.‘);
5 }
6 alert(variableA); //2
1 alert(variableA); //function variableA(){alert(‘I am variableA.‘)}
2 function variableA(){
3     alert(‘I am variableA.‘);
4 }
5 var variableA = 2;
6
7 alert(variableA); //2

示例5:

1 alert(variableA); //undefined
2 var variableA = function(){
3     alert(‘I am variableA.‘);
4 }
5 alert(variableA); //function variableA(){alert(‘I am variableA.‘)}
1 alert(variableA); //undefined
2 var variableA = function variableA(){
3     alert(‘I am variableA.‘);
4 }
5
6 alert(variableA); //function variableA(){alert(‘I am variableA.‘)}
时间: 2025-01-31 07:33:36

JavaScript解析机制的相关文章

javascript解析机制——预解析

JavaScript解析机制是什么? JavaScript解析过程分为两个阶段,一个是编译阶段,另外一个就是执行阶段. * 编译阶段         编译阶段就是我们常说的JavaScript预解析(预处理)阶段,在这个阶段JavaScript解释器将完成把JavaScript脚本代码转换到字节码. * 执行阶段 在编译阶段JavaScript解释器借助执行环境把字节码生成机械码,并顺序执行. 编译阶段(预解析阶段)做什么操作? * var , function声明的变量提升 首先,创建一个当前

轻松搞定javascript预解析机制(搞定后,一切有关变态面试题都是浮云~~)

hey,guys!我们一起总结一下JS预解析吧! 首先,我们得搞清楚JS预解析和JS逐行执行的关系.其实它们两并不冲突,一个例子轻松理解它们的关系: 你去酒店吃饭,吃饭前你得看下菜谱,点下菜(JS预解析),但吃的时候还是一口一口的吃(JS逐行执行)! OK,解决下面五个问题,JS预解析就算过了~~(前提:对JS变量作用域有清晰理解) 一.JS预解析是什么? 其实就是对程序要用到的材料(变量,函数)给一个初始值,并存到一个表中(我自己虚构的),当程序运行到那一行时,就来这个表看有没有初始值,没有就

从var func=function 和 function func()区别谈Javascript的预解析机制

var func=function 和 function func()在意义上没有任何不同,但其解释优先级不同:后者会先于同一语句级的其他语句. 即: { var k = xx(); function xx(){return 5;} } 不会出错,而 { var k = xx(); var xx = function(){return 5;} } 则会出错. 为什么会这样呢?这就要引出javascript中的预解析机制来解释了. JavaScript解析过程分为两个阶段,一个是编译阶段,另外一个

进击JavaScript核心 --- (2)函数和预解析机制

一.函数 每个函数都是 Function类型的实例,也具有属性和方法.由于函数也是一个对象,因此函数名实际上也是一个指向函数对象的指针,不会与某个函数绑定 1.函数的定义方式 (1).函数声明 function add(a, b) { return a + b; } 函数声明提升:在执行代码之前,会先读取函数声明,也就是说,可以把函数声明放在调用它的代码之后 fn(); // 1 function fn() {console.log(1)} (2).函数表达式 var add = functio

JavaScript 运行机制详解

JavaScript 运行机制详解——转载: 一.为什么JavaScript是单线程? JavaScript语言的一大特点就是单线程,也就是说,同一个时间只能做一件事.那么,为什么JavaScript不能有多个线程呢?这样能提高效率啊. JavaScript的单线程,与它的用途有关.作为浏览器脚本语言,JavaScript的主要用途是与用户互动,以及操作DOM.这决定了它只能是单线程,否则会带来很复杂的同步问题.比如,假定JavaScript同时有两个线程,一个线程在某个DOM节点上添加内容,另

JavaScript 运行机制

JavaScript 运行机制 阅读目录 一.为什么JavaScript是单线程? 二.任务队列 三.事件和回调函数 四.Event Loop 五.定时器 六.Node.js的Event Loop 七.关于setTimeout的测试 一.为什么JavaScript是单线程? JavaScript语言是单线程,也就是说,同一个时间只能做一件事. JavaScript的单线程,与它的用途有关.作为浏览器脚本语言,JavaScript的主要用途是与用户互动,以及操作DOM.这决定了它只能是单线程,否则

javascript运行机制之执行顺序

前言 JavaScript是一种描述型脚本语言,它不同于java或C#等编译性语言,它不需要进行编译成中间语言,而是由浏览器进行动态地解析与执行.如果你不能理解javaScript语言的运行机制,或者简单地说,你不能掌握javascript的执行顺序,那你就犹如伯乐驾驭不了千里马,让千里马脱缰而出,四处乱窜. 那么JavaScript是怎么来进行解析的吗?它的执行顺序又是如何的呢?在了解这些之前,我们先来认识几个重要的术语: 代码块 JavaScript中的代码块是指由<script>标签分割

JavaScript执行机制

原文 简书原文:https://www.jianshu.com/p/0d2d42fbe1dc 大纲 1.场景分析 2.执行机制相关知识点 3.以实例来说明JavaScript的执行机制 4.相关概念 1.场景分析 /* 以下这段代码的执行结果是什么? 如果依照:js是按照语句出现的顺序执行这个理念, 那么代码执行的结果应该是: //"定时器开始啦" //"马上执行for循环啦" //"执行then函数啦" //"代码执行结束"

[转]JavaScript异步机制详解

原文: https://www.jianshu.com/p/4ea4ee713ead --------------------------------------------------------------------------- 学习JavaScript的时候了解到JavaScript是单线程的,刚开始很疑惑,单线程怎么处理网络请求.文件读写等耗时操作呢?效率岂不是会很低?随着对这方面内容的了解和深入,知道了其中的奥秘.本篇文章就主要讲解一下JavaScript怎么处理异步问题. 一.同