JavaScript运行过程中的“预编译阶段”和“执行阶段”
来源:互联网 发布:centos 7 nginx 目录 编辑:程序博客网 时间:2024/06/08 00:38
javascript相对于其它语言来说是一种弱类型的语言,在其它如java语言中,程序的执行需要有编译的阶段,而在javascript中也有类似的“预编译阶段”(javascript的预编译是以代码块为范围<script></script>,即每遇到一个代码块都会进行 预编译>执行),了解javascript引擎的执行机理,将有助于在写js代码过程中的思路总结
首先科普下javascript中的两种声明方式,var和function,前者声明的是变量,后者声明的是方法
在预编译中,javascript对这两种声明做出了两种处理方案
以上代码块中,a、c为变量赋值,b为函数声明,当执行以上的代码时,首先会进入预编译阶段,对与变量赋值a、c会在内存中开辟一块内存空间并指向变量名,且赋值为undefined
对于函数声明,则同样会进行开辟内存空间,但赋值的对象会将声明的函数赋值给函数名
预编译阶段:(PS:不管代码中声明变量和声明函数的顺序如何,在预编译阶段会先声明变量,再声明函数)
<script> vara = undefined; varc = undefined; varb = function(){ alert(); } </script>
执行阶段:
<script> a = "1"; c = function(){ alert(); }</script>
整体执行步骤:
<script> vara = undefined; varc = undefined; varb = function(){ alert(); } a = "1"; c = function(){ alert(); }</script>
题目:
<script> vara = "1"; functionb(){ alert(a); vara = "2"; } b();</script>
ps:javascript的预编译
一、先预定义变量,再预定义函数
二、变量的预编译只作声明,不作初始化,初始化在执行时
三、function语句定义的函数,不仅声明了函数名,而且函数体也进行了处理
四、匿名函数不会预编译
function f(){ // 声明函数f return 1; } alert(f()); // 返回1var f = function(){ // 定义匿名函数f return 2; } alert(f()); // 返回2
先预定义了变量f,然后同名函数f()覆盖了变量f,所以第一次输出1;变量的预编译
var f = function(){ // 定义匿名函数f return 1; }alert(f()); // 返回1function f(){ // 声明函数f return 2; }alert(f()); // 返回1
先预定义了变量f,然后同名函数f()覆盖了变量f.
0 0
- JavaScript运行过程中的“预编译阶段”和“执行阶段”
- javascript运行过程中的“预编译阶段”和“执行阶段”
- javascript运行过程中的“预编译阶段”和“执行阶段”
- Javascript预编译和执行过程
- Javascript预编译和执行过程
- Javascript预编译和执行过程
- Javascript预编译和执行过程
- javascript代码运行分两个阶段:预解析,执行
- Apache的启动阶段和运行阶段
- 统一过程中的四个阶段
- 在预编译阶段打印提示信息
- 在预编译阶段打印提示信息
- 在预编译阶段判断ios版本
- uboot第1阶段执行过程
- Javascript的预编译和执行顺序
- javascript的预编译和执行顺序
- JavaScript代码运行分为几个阶段
- WINCE编译过程中的错误出现阶段
- 通过广播简单实现sms短信的发送和接收
- java 调用webview js方法, webview js调用java方法
- Jsp语法
- spring + maven 基于注解的配置(2)
- 网站测试流程与规范
- JavaScript运行过程中的“预编译阶段”和“执行阶段”
- 动态规划--钢条切割
- Javascript面向对象编程
- ListView(头部+下拉筛选+顶部悬停)
- 检测MySQL负载过高及解决方法(详解SSH TOP命令)
- RTMP流媒体播放过程
- Centos 建立用户
- Tkinter教程之Canvas篇(3)
- iOS开发---本地通知(UILocalNotification)