LHS和RHS

LHS:当变量出现在赋值操作的左侧时进行LHS查询
     LHS查询试图找到变量容器本
     如果查找的目的是对变量进行赋值,就会使用LHS
RHS:当变量出现在赋值操作的右侧时进行RHS查询
     RHS查询就是简单的查找某个 变量的值
     如果目的是获取变量,就会使用RHS
 console.log(a)//其中对a的引用是一个RHS引用,因为其中的a并没有赋予
               //任何的值,这里需要查找并取得a的值
LHS和RHS的含义是“赋值操作的左侧和右侧”,并不一定意味着“=”赋值操作符的左侧或者右侧。
LHS:赋值操作的目标
RHS:赋值操作的源头
function foo(a){
    console.log(a);
};
foo(2);
  1. 调用函数foo(...)时对函数进行RHS引用
  2. 代码中隐式的a=2,是LHS查询,给参数a分配值
  3. 对console对象进行RHS查询,检查得到的值总是否有一个叫做log的方法
  4. console.log(.....)中对a进行RHS引用
不成功的RHS引用会导致程序抛出ReferenceError异常
不成功的LHS应用会导致自动隐式地创建一个全局变量(非严格模式下),该变量使用LHS引用的目标作为标识符,或者抛出ReferenceError异常(严格模式下)

你可能感兴趣的:(LHS和RHS)