为什么区分LHS和RHS?

因为在变量还没声明(在任何作用域中都无法找到该变量)情况下,这两种查询行为是不一样的。

LHS与RHS是JavaScript引擎的两种查找类型。

RHS:需要获取那个变量的值,就是对那个变量的值进行RHS引用,理解为赋值操作的源头。(=1)

LHS:对那个赋值就是对那个进行LHS引用,可以理解为赋值操作的目标.(var a)

例一:

var a = 1;

将其以等式拆为两个部分:var a和=1.var a 则是进行LHS查询,编译器遇到var a,会询问作用域是否存在一个名为a的变量,如果有的忽略,没有则让作用域声明一个名为a的变量(过一会来存储数字1);=1则进行RHS查找,也就是查找数字本身的值(即数字1的屋里地址),然后将1赋值给a.

例二:

例子:
console.log(a)里面LHS和RHS
(1)由于a没有赋予任何值,因此需要找a原本的值, 即RHS
(2)console也是要进行RHS查询因为要查找是否有一个log方法

你可能感兴趣的:(前端知识重点总结,js,javascript)