javascript学习笔记一【预解释】

来源:互联网 发布:表格怎么把相同的数据 编辑:程序博客网 时间:2024/04/30 18:29


1、当浏览器加载HTML页面时,首先会提供一个供全局JS代码执行的环境->全局作用域(global/window).

2、预解释(变量提声) 在当前的作用域中,JS代码执行之前,浏览器首先会默认的把所有带var或function的进行提前的声明或者定义

  1)理解声明和定义

   var num=12;

        声明(declare):var num;->告诉浏览器在全局作用域中有一个var变量,如果一个变量只是声明了但是没有赋值默认值是undefined

定义(define):num=12;->给我们的变量进行赋值

  2)var-> 在预解释的时候只是提前声明

  function->在预解释的时候提前的声明+定义都完成了

var num=12;var obj={name:"珠峰培训",age:7};function fn(num1,num2){    var total=num1+num2;    console.log(total);}

  3)、预解释只发生在当前作用域下,开始只对window下的进行预解释, 注意var total 在当前作用域下在函数fn中只是以字符串形式存在,不是代码不进行预解释,对于函数中的代码只有在函数执行时才进行预解释


预解释图解


程序执行图解

3、JS中内存分类

栈内存:用来提供供JS代码执行的环境->作用域(全局作用域/私有作用域)

堆内存:用来存储引用数据类型的值->对象存储的是属性名和属性值,函数存储的是代码字符串


预解释例子


预解释例子答案



下图fn与fn()的区别图解




无节操预解释






JS函数不同写法有不同的预解释,匿名函数之函数表达式写法在函数声明前执行函数不可行,只能在声明后执行。但推荐匿名函数之函数表达式

 var fun=function(){};

这种函数声明方式,因便于查找排错。




自执行函数预解释




带有return的函数的预解释



名字声明过的预解释