快速理解 JavaScript 中的 LHS 和 RHS 查询的用法


Posted in Javascript onAugust 24, 2017

JavaScript 程序中的一段源代码在执行之前会经历三个步骤,统称为 编译

  • 分词/词法分析
  • 解析/语法分析
  • 代码生成

先看原书对一个赋值操作的拆解说明:
变量的赋值操作会执行两个动作,首先编译器会在当前作用域中声明一个变量(如果之前没有声明过),然后在运行时引擎会在作用域中查找该变量,如果能够找到就会对它赋值。 --- 《你不知道的JavaScript(上卷)》 P7

而要讲的 LHS 和 RHS 就是上面说的对变量的两种查找操作,查找的过程是由作用域(词法作用域)进行协助,在编译的第二步中执行。

LHS 和 RHS

  • 字面意思其实是 Left Hand Side Right Hand Side 即左手边和右手边
  • 一般可以理解为 赋值操作的左侧和右侧

先看个例子一

console.log(a);

这里对 a 是一个 RHS 引用,因为 a 并没有赋予任何值,目的是为了取到 a 的值并打印出来。

a = 2;

这里对 a 是一个 LHS 引用,因为实际上我们不关心当前的值是什么,只是想要把 a 赋值为 2。

再看例子二

function foo(a) {
  console.log(a); // 2
}
foo(2);
  • 最后一行foo(..)函数的调用需要对 foo 进行 RHS 引用,意味着是取到 foo 的值,并且 (..)意味着 foo 需要被执行,因此它最好是一个函数类型的值
  • 其中有一个容易被忽略的隐式赋值操作 a = 2,它发生在 2 被当做实参传入 foo 中时。即实参 2 传给了形参 a,需要一个 LHS 查询
  • console 那一行还有对 a 的一次 RHS 引用(或者叫查询),同时console.log(..)本身也需要一个 RHS 引用,即对 console 对象进行 RHS 查询,并且检查得到的值中是否有一个叫做 log 的方法。
  • 书中有一段引擎和作用域的对话,有助于很好的理解例子二,see YDKJS github

小测验

function foo(a) {
  var b = a;
  return a + b;
}
var c = foo(2);

试试找出其中的3处 LHS 查询,4处 RHS 查询

答案:

LHS 查询:

c = ..;
a = 2(隐式变量分配)
b = ..

RHS 查询

foo(2..
= a;
a ..
.. b

小结

参考原书中文版P12,英文版见 github

  • 作用域是一套规则,用于确定在何处以及如何查找变量(标识符)。
  • 如果查找的目的是对变量进行赋值,就会使用 LHS 查询;如果目的是获取变量的值,就会用 RHS 查询。
  • 赋值操作会导致 LHS 查询。 = 操作符或调用函数时传入参数的操作都会导致关联作用域的赋值操作, 即都会导致 LHS 查询。
  • JavaScript 引擎首先会在代码执行前对其进行编译,在这个过程中,像var a = 2 这样的声明会被分解成两个独立的步骤:
  • 首先,var a在其作用域中声明新变量。这会在最开始的阶段,也就是代码执行前进行。
  • 接下来,a = 2会查询(LHS查询)变量 a 并对其进行赋值。
  • LHS 和 RHS 查询都会在当前执行作用域中开始,如果有需要(也就是说它们没有找到所需的标识符),就会向上级作用域继续查找目标标识符,这样每次上升一级作用域,最后到达全局作用域,无论找到或没找到都将停止。
  • 不成功的 RHS 引用会导致抛出 ReferenceError 异常。不成功的 LHS 引用会导致自动隐式地创建一个全局变量(非严格模式下),该变量使用 LHS 引用的目标作为标识符,或者抛出 ReferenceError 异常(严格模式下)。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
用js正确判断用户名cookie是否存在的方法
Jan 28 Javascript
JavaScript常用的返回,自动跳转,刷新,关闭语句汇总
Jan 13 Javascript
jquery增加和删除元素的方法
Jan 14 Javascript
HTML中setCapture、releaseCapture 使用方法浅析
Sep 25 Javascript
Boostrap实现的登录界面实例代码
Oct 09 Javascript
原生JavaScript来实现对dom元素class的操作方法(推荐)
Aug 16 Javascript
亲自动手实现vue日历控件
Jun 26 Javascript
浅谈layui数据表格判断问题(加入表单元素),设置单元格样式
Oct 26 Javascript
如何在Node和浏览器控制台中打印彩色文字
Jan 09 Javascript
在vue中实现禁止回退上一步,路由不存历史记录
Jul 22 Javascript
浅谈vue项目利用Hbuilder打包成APP流程,以及遇到的坑
Sep 12 Javascript
详解JavaScript中分解数字的三种方法
Jan 05 Javascript
vue不通过路由直接获取url中参数的方法示例
Aug 24 #Javascript
VueJS 集成 Medium Editor的示例代码 (自定义编辑器按钮)
Aug 24 #Javascript
JS实现电商放大镜效果
Aug 24 #Javascript
weui框架实现上传、预览和删除图片功能代码
Aug 24 #Javascript
jQuery Datatable 多个查询条件自定义提交事件(推荐)
Aug 24 #jQuery
详解webpack2+node+react+babel实现热加载(hmr)
Aug 24 #Javascript
Vue网页html转换PDF(最低兼容ie10)的思路详解
Aug 24 #Javascript
You might like
php 应用程序安全防范技术研究
2009/09/25 PHP
PHP对接微信公众平台消息接口开发流程教程
2014/03/25 PHP
在Ubuntu 14.04上部署 PHP 环境及 WordPress
2014/09/02 PHP
完美解决phpdoc导出文档中@package的warning及Error的错误
2016/05/17 PHP
js实现的网页颜色代码表全集
2007/07/17 Javascript
重载toString实现JS HashMap分析
2011/03/13 Javascript
了解一点js的Eval函数
2012/07/26 Javascript
JavaScript判断字符长度、数字、Email、电话等常用判断函数分享
2015/04/01 Javascript
jQuery点击按钮弹出遮罩层且内容居中特效
2015/12/14 Javascript
基于JavaScript如何制作遮罩层对话框
2016/01/26 Javascript
基于JS实现回到页面顶部的五种写法(从实现到增强)
2016/09/03 Javascript
详解基于Node.js的微信JS-SDK后端接口实现代码
2017/07/15 Javascript
JavaScript引用类型Array实例分析
2018/07/24 Javascript
node.js读取Excel数据(下载图片)的方法示例
2018/08/02 Javascript
Vue监听事件实现计数点击依次增加的方法
2018/09/26 Javascript
微信小程序导入Vant报错VM292:1 thirdScriptError的解决方法
2019/08/01 Javascript
解决vue项目本地启动时无法携带cookie的问题
2021/02/06 Vue.js
学习python (1)
2006/10/31 Python
Python CSV模块使用实例
2015/04/09 Python
python实现查找excel里某一列重复数据并且剔除后打印的方法
2015/05/26 Python
python中urllib.unquote乱码的原因与解决方法
2017/04/24 Python
python实现excel读写数据
2021/03/02 Python
twilio python自动拨打电话,播放自定义mp3音频的方法
2019/08/08 Python
Python 用turtle实现用正方形画圆的例子
2019/11/21 Python
简单了解Python write writelines区别
2020/02/27 Python
Python函数生成器原理及使用详解
2020/03/12 Python
Python绘图之二维图与三维图详解
2020/08/04 Python
Python常用模块函数代码汇总解析
2020/08/31 Python
pandas实现导出数据的四种方式
2020/12/13 Python
JSF面试题:Jsf中的核心类用那些?有什么作用?LiftCycle六大生命周期是什么?
2014/07/17 面试题
法学专业个人求职信
2013/09/26 职场文书
学生手册评语
2014/05/05 职场文书
专题民主生活会对照检查材料思想汇报
2014/09/29 职场文书
发展党员工作情况汇报
2014/10/28 职场文书
五四青年节比赛演讲稿
2015/03/18 职场文书
2015银行年终工作总结范文
2015/05/26 职场文书