重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章给大家分享的是有关浏览器解析JavaScript的方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。
创新互联公司是专业的东洲网站建设公司,东洲接单;提供成都做网站、成都网站制作、成都外贸网站建设,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行东洲网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
浏览器解析JavaScript原理特点:
1、跨平台
2、弱类型 javascript 定义的时候不需要定义数据类型,数据类型是根据变量值来确定的.
var a = 10; //数字类型 var a = true //boolean类型
( 强类型: 定义变量的时候需要定义变量的类型:例如java,C#中的int a = 10 boolean a = true,直接确定了数据类型)
3、解释执行,逐行执行
javascript 执行过程
1、语法检测
就是看你有没有基本的语法错误,例如中文,关键字错误...
2、词法分析(预编译)
3、逐行执行
词法分析
预编译的过程(两种情况)
1、全局(直接是script标签中的代码,不包括函数执行)
以下面demo为例:
console.log(a); console.log(b) var a = 100; console.log(a) var b = 200 var c = 300 function a(){ } function fun(){ }
执行前:
1)、 首先生成一个GO(global object)对象,看不到,但是可以模拟出来用来分析
GO = { //自带的属性都不写 }
2) 、分析变量声明,变量名为属性名,值为undefined
GO = { a : undefined, b : undefined, c : undefined }
3)、分析函数声明,函数名为属性名,值为函数体,如果函数名和变量名相同,则无情覆盖
GO = { a : function a(){ }, b : undefined, c : undefined, fun : function fun(){ } }
此时,GO就是预编译完成的最终对象,词法分析结束。
4)、 逐行执行,分析过(变量声明,函数声明)不用管了,只管赋值(变量赋值)
a赋了一次值,值改变为100 GO = { a : 100, b : undefined, c : undefined, fun : function fun(){ } }
2、局部( 函数执行的时候)
以这个demo为例:
num = 100510)
1)、预编译的时候
GO = { num : undefined, fun : function }
2)、执行过程
GO = { num : 100, fun : function }
3)、函数调用,也是会生成自己的作用域(AO:active object),AO活动对象. 函数调用时候,执行前的一瞬间产生的,如果有多个函数的调用,会产生多个AO
ⅰ、函数执行前的一瞬间,生成AO活动对象
fun.AO = { }
ⅱ、 分析参数,形参作为对象的属性名,实参作为对象的属性值
fun.AO = { num : 5 }
ⅲ、分析变量声明,变量名为属性名,值为undefined,如果遇到AO对象上属性同名,不去做任何改变
fun.AO = { num : 5 }
ⅳ、分析函数声明,函数名为属性名,值为函数体,如果遇到AO对象上属性同名,则无情覆盖(在这里没有函数声明,跳过)
4)逐行执行
实例:
在这里我们看几个实例:
实例1:
实例2:
感谢各位的阅读!关于浏览器解析JavaScript的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!