JS预编译过程

首先讲预编译过程

JS代码执行过程三部曲

过程

  1. 语法分析:首先扫描一遍,看有没有低级的语法错误
  2. 预编译
  3. 解释执行:解释一行执行一行

预编译low讲

  1. 函数声明整体提升,变量 的声明提升(这个其实很low,点击low点)

假如没有预编译的话

a();
function a(){console.log("a")
}
先调用再声明,在没有预编译的情况下,不能正常输出,但是有了预编译就可以正常输出,这就是函数整体提升;
定义一个变量  var a = "1233"   这个过程叫做变量的声明 和 赋值 
console.log(a); //undefined
var a = "1233"
变量   声明提升,但是赋值未被提升

low点

函数声明整体提升,变量 的声明提升 上面说的这两个点不能解释下面的代码
  console.log(a);var a = "aaaa";function a(a){var a = 5;}

手动懵逼why???
在这里插入图片描述
真·预编译☞前奏
暗示全局变量 imply global

1.任何变量未经声明就赋值,这个变量就为全局对象(window)所拥有;
----------------------------------------------------------------------------------------------------
2.全局上声明的任何变量,即使声明了也归window 所有;window就是全局的域.
 a = 1;var b = 2;

在这里插入图片描述

 function ddd(){var a = b = 12;//赋值是从右向左,,虽然是在函数局部作用域内,12先赋值给了b,b并没声明所以b是属于window的,a是局部的,然后b在赋值给 a}ddd()

在这里插入图片描述
真·预编译四部曲
AO 对象中四步

预 编 译 发 生 在 函 数 执 行 的 前 一 刻
function fn(a){console.log(a);var a = 123;console.log(a);function a(){}console.log(a);var b = function () {};console.log(b);}
fn(1)
1. 创建AO对象,Activation Object (执行期上下文)
AO{ }
  1. 找形参和变量的声明,将变量的和形参名作为AO属性名,值为undefined
AO{a:undefined,b:undefined,	}
  1. 将实参和形参统一
AO{a:1,b:undefined,	}
  1. 在函数体里面,找 函数声明,值赋予 函 数 体;
AO{a:function a(){}//  把形参覆盖了  注意:**function a(){} 是函数声明 只有它能提升; var b = function(){}这种是表达式**b:undefined,	}

到此AO 对象创建完了
然后马上执行函数了 电脑从 AO 对象里面 拿东西

所以第一次打印的是function a(){},

a 被赋值123,第二次打印的是123,

然后因为function a(){}已经被提升上去,所以不用看,第三次打印也是123,

第四次打印的function ({被提升,所以最后一次打印是function(){}}
输出
在这里插入图片描述

    // }
function test(a,b){console.log(a);	 //function a(){};console.log(b);	//undefinedvar b = 234;console.log(b)	//234a = 123;console.log(a);	//123function a(){};var a ;b = 234;var b = function(){};console.log(a);	//123console.log(b);	//function(){};
}
test(1)
		1.  AO:{//过程}2.  AO:{a:undefined;b:undefined;}3.  AO:{a:1;b:undefined;}4.  AO:{a:function a(){};b:undefined;}
所以第一次输出的a是 function a(){};b 是undefined
b=234AO:{a:function a(){};b:234;}下个b输出就是234a = 123AO:{a:123;b:234;}下个a输出就是123

===中间的声明对AO对象不产生影响所以输出不变

 var b = function(){};AO:{a:123;b:function(){};}

在这里插入图片描述
GO 对象 global object 全局的执行上下文 === window
其实差不多

console.log(a) // 输出的 function a(){}var a = 123;
function a(){
}
console.log(a) //123
1.GO{}
2.GO{a:undefined}
3.GO{a:function a(){}}
4.GO{a:123}

GO AO 一起的

console.log(test); //  这个 输出的是 function test(){},完了之后,就该调用函数了
function test(test){console.log(test); // function test(){} 这个是自己的testvar test = 123;console.log(test); //123function test(){}
} 
test(1);
var test = 123;

理解了预编译就很简单
在这里插入图片描述

【注】局部输出或者使用一个变量,或者方法,假如说内外部都有,优先使用内部的(局部的),局部没有才去全局找
这一点来个超级无敌简单的例子:
var global = 100;
function fn(){console.log(global) // 100;
}
fn()
很简单输出的  100过程  先来个全局 GO 对象 从上到下
GO{global:100,fn:function(){...},
}然后执行 fn 来个局部的  AOAO{//  什么都没有,么有变量和形参声明,只能去全局GO里面找global 就输出; 100}
global = 100;function fn(){console.log(global); //undefinedglobal = 200;console.log(global); //200var global = 300;console.log(global) //300}fn()var global;

在这里插入图片描述

function test(){console.log(b); //undefinedif(a){ //a == undefined ==>falsevar b = 100; //跳过赋值}console.log(b)undefinedc  = 234;console.log(c) //234
}
var a ;
test();
a = 10;
console.log(c)
// GO{
//  a:undefined;
// test:function(){...}
// }// AO{
//  b:undefined,  预编译,可以跳过循环,循环语句里的变量声明已经写入了内存,所以输出是undefined
//  变量c在函数内部没有声明,就被全局接受,【参考以上知识点】
//}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/407008.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

codeforces 476B.Dreamoon and WiFi 解题报告

题目链接:http://codeforces.com/problemset/problem/476/B 题目意思:给出两个字符串str1, str2,其中,str1 只由 和 - 组成,而str2 由 ,-和?组成。初始点在原点0的位置,经过 str1 的变换最终会…

在应用程序级别以外使用注册为 allowDefinition='MachineToApplication' 的节是错误

在应用程序级别以外使用注册为 allowDefinitionMachineToApplication 的节是错误 在web.config文件之外注册为 allowDefinitionMachineToApplication 的节是错误 遇到这个问题,我真是晕啊! 以下是我个人的经验解决上述的二个问题,至今有时还…

bash删除文件中的空行

方法一:sed /^$/d a.txt 所以如果要将删除后的结果替换原文件中的内容,就可以用: sed /^$/d a.txt > temp; mv temp a.txt 然后在弹出提示符下选择Y就可以了。 方法二:在vi命令提示符下,输入:%s/^\n/…

Taro+react开发(50) 小程序触底操作

onReachBottom() {console.log("我在触底");const { pageIndex, pageSize, getStauList } this.state;if (pageIndex * pageSize > getStauList.length) return;this.setState({pageIndex: pageIndex 1},() > {this.getStatusList();});}

记腾讯互娱网站布局(3)

3.图文回顾 先看看整个网站的全貌 这里’display:table;width:100%;table-layout:fixed’是约定俗成的写法,用来保证固定的表单布局,同时让连续的英文单词不会超出 内部采用’display:table-cell’属性将内容当做表格的td标签一样显示,设置v…

JS阻止冒泡和取消默认事件(默认行为)

阻止事件冒泡 function stopPropagat(e) {if (e && e.stopPropagation) {e.stopPropagation();//标准浏览器} else {window.event.cancelBubble true;//兼容IE的方式来取消事件冒泡}}阻止默认行为 function stopDefault(e) {if (e && e.preventDefault) {e.pr…

如何提高个人的职涯“本钱”

何所谓职业生涯的本钱?简单来说,必须涵盖三个方面,一是充分的能力,包括专业技能、管理知识的储备等;二是态度,即工作态度及风格是否契合你所希望就职公司的文化,开阔的视野、兼容并包的心胸、善…

Taro+react开发(51) 数组对象和数组得处理

for (var key of value) {arrcode.push(selectorIndustry.find(obj > obj.value key));}

简单的python流回显服务器与客户端

环境:Fedora12 python2.6.2 server.py #!/usr/bin/python import socket srvsock socket.socket(socket.AF_INET, socket.SOCK_STREAM) srvsock.bind((, 5000))srvsock.listen(5) while True:clisock, (remoteHost, remotePort) srvsock.accept()str11 clisock…

MongoDB 入门之安装篇

前言:MongoDB 在各 OS 上的安装比较简单,此文章只用来记录,不考虑技术深度。 一、Ubuntu 导入 MongoDB 公钥,添该软件源文件,更新源列表sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 7F0CEB10 …

大小不固定的图片和多行文字的垂直水平居中

1. 单行文字 可能很多人都知道如何让单行文字垂直居中显示,就是使用line-height,将line-height值与外部标签盒子的高度值设置成一致就可以了 2. 多行文字 说白了就是把文字当图片处理。用一个span标签将所有的文字封装起来,设置文字与图片相…

移动端中使用调试控制台

一、一般移动端&#xff1a;在html head中引入移动端调试控制台代码并初始化&#xff1a; <head><meta charset"UTF-8">....<!-- 移动端调试控制台 --><script src"https://cdn.bootcss.com/eruda/1.4.3/eruda.min.js"></scri…

网络安全解决方案

中小企业网络安全解决方案转载于:https://blog.51cto.com/405214606/144453

Taro+react开发(52) 移动端弹出框使用

<AtFloatLayoutisOpened{isOpened}title"所属行业"onClose{this.handleClose.bind(this)}><View><AtCheckboxoptions{selectorIndustry}selectedList{industryCodeList}onChange{this.handleCheckChange.bind(this)}/></View></AtFloatLa…

GPT每预测一个token就要调用一次模型

问题&#xff1a;下图调用了多少次模型&#xff1f; 不久以前我以为是调用一次 通过看代码是输出多少个token就调用多少次&#xff0c;如图所示&#xff1a; 我理解为分类模型 预测下一个token可以理解为分类模型&#xff0c;类别是vocab的所有token&#xff0c;每一次调用都…

display:table-cell的集中应用

1. display:table-cell属性指让标签元素以表格单元格的形式呈现&#xff0c;类似于td标签。我们都知道&#xff0c;单元格有一些比较特别的属性&#xff0c;例如元素的垂直居中对齐&#xff0c;关联伸缩等&#xff0c;所以display:table-cell还是有不少潜在的使用价值的 与其他…

第三讲系统的基本操作

第三讲系统的基本操作转载于:https://blog.51cto.com/ccccc/145262

移动端click延迟和tap事件

一、click等事件在移动端的延迟 click事件在移动端和pc端均可以触发&#xff0c;但是在移动端有延迟现象。 1、背景 由于早期移动设备浏览网页时内容较小&#xff0c;为了增强用户体验&#xff0c;苹果公司专门为移动设备设计了双击放大的功能&#xff0c;以确保用户可以方便…

Taro+react开发(53) Taro提示操作

if (res.data.returnCode 0) {Taro.showToast({title: "操作成功",duration: 2000});Taro.navigateTo({url: /pages/companyIntroDetail/index});}

结构 struct

结构 struct 结构是使用struct关键字定义的 结构与类相似,但有两大区别: 1.结构属于值类型,而类属于引用类型; 2.结构是隐式密封的,也就是不可继承的,而一般的类不是隐式密封的. 其他区别: 3.结构中不能再定义无参数构造函数或析构函数,而类中可以 4.结构中普通字段不能直接赋值…