关于预解释



咋回事

当HTML代码运行到script标签的时候,就会行成一个全局的作用域window,首先找到带var关键字的,然 后在这个作用域下给挖个坑,紧接着从上到下执行,基本数据类型在当前作用域下就开了一个值,并且让这个值和我们var的那个变量联系在一起;对象数据类型与其不同的地方就是,他不能直接在当前作用域下开空间,他是单独的开辟了一个新的空间,并且让这个空间的内存地址和我们var 的那个变量产生关联。这样我们定义的那个对象数据类型的变量就存储的是对这个空间的引用地址
       
预解释 var 

var num=12;//定义是不准确的

我们口中的定义:声明declear 定义define

在当前作用域下,开始执行代码之前,我们首先找到所有带var关键字的,然后在当前作用域下给“挖个坑”(也就是我们的声明一个变量),这种机制就是预解释
 var num=12 : 声明num--开辟12这个值---让我们声明的num和开辟的12产生关联
 只是声明没有定义的话,变量的值是undefined


  
 预解释 function
在当前作用域下,代码执行前,首先找到所有带function关键字的,然后在当前作用域下声明,不仅如此,声明的同时,新开了一个内存地址(function也是引用数据类型),然后里面存储的是整个function中的js代码,但是现在的代码没有任何的意义,只是一堆字符串;然后让声明的函数名和我们内存的地址之间产生关联,这些都是在预解释的时候完成的,一定要和var区分开


预解释中,优先级函数预解释比较高:他会把声明和定义一起完成的先预解释


无节操:  
预解释是一种没有节操的机制,不管你的if条件是否成立,if里面的带var和function的都要预解释
  

预解释是一种没有节操的机制,在一个作用域下,如果当前的变量或者函数名被预解释了,那么接下来不会重复的预解释

  
预解释是一种没有节操的机制:函数体中return后面的语句也会预解释,但是return紧跟着的返回的这个语句不预解释


另外

预解释只在同一个脚本区域内有作用,在不同的script中不能相互的识别

预解释只对=左边的起作用,=右边的不进行预解释

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值