前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JavaScript中的变量查找

JavaScript中的变量查找

作者头像
娜姐
发布2022-05-13 14:28:00
1.5K0
发布2022-05-13 14:28:00
举报
文章被收录于专栏:娜姐聊前端

众所周知,JavaScript变量是按照作用域链来进行查找的(作用域和作用域链相关知识可参看我的另一篇文章,《基于JavaScript作用域链的性能调优》), 那么,对于一个简单的赋值操作,等号左右两边变量的查找方式一样吗?让我们从一个简单例子讲起~

代码语言:javascript
复制
console.log(a);   // undefined
var a = 3;
console.log(a);   // 3

console.log(b);  // ReferenceError
b = 4;
console.log(b);  //4
1. LHS(left-hand-side左查找)和RHS(right-hand-side右查找)

概念如下:

  • LHS查询:试图找到变量容器本身,从而可以对其进行赋值
  • RHS查询:查找某个变量的值

对于一个赋值语句var a = b;,等号左侧进行LHS查询,等号右侧进行RHS查询;如果是一个普通的打印语句console.log(a),那么,查找变量a属于RHS查询。

两者的相同之处:都遵循作用域链查找

2. LHS和RHS查询区别

(1) LHS查询

当JavaScript引擎执行LHS查询时,如果在顶层作用域中无法找到目标变量,那么,就会在全局作用域中创建一个具有该名称的变量,并将其返回给引擎(非严格模式下)。

要注意,这种方式创建的全局变量,严格上来讲并不是真正的变量,而是全局对象的属性,可以通过delete操作符将其删除。但是,用var声明的全局变量,是不可以用delete操作符删除的。

参考文章首部的例子:

代码语言:javascript
复制
b = 4;
console.log(b);  // 4
delete b;
console.log(window.b); // undefined

程序中并没有声明变量b,但是由于LHS查询会自动创建未找到的目标变量,所以,打印b返回4。然后删除b,可删除成功。

如果是严格模式:

代码语言:javascript
复制
"use strict";
b = 4;
console.log(b);  

这时LHS查询将无法自动创建未声明的目标变量,所以,打印b时抛出异常:Uncaught ReferenceError: b is not defined

(2) RHS查询

当JavaScript引擎执行RHS查询时,如果在作用域链中都无法找到目标变量,那么,引擎会抛出ReferenceError异常。

参考文章首部的例子:

代码语言:javascript
复制
console.log(b);  
b = 4;

RHS查询变量b,在全局作用域中未曾找到该变量定义,于是,引擎抛出异常Uncaught ReferenceError: b is not defined

3. 小贴士

(1) 变量提升

概念:用var声明的变量,总是会被JavaScript解释器悄悄地“提升”到方法体的最顶部。

参考文首的例子:

代码语言:javascript
复制
console.log(a); 
var a = 3;

JavaScript引擎会将其解析为:

代码语言:javascript
复制
var a = undefined;
console.log(a); 
a = 3;

所以,第一次打印a时会返回undefined

(2) ReferenceError和TypeError

ReferenceError代表作用域判别失败,也就是作用域内查询变量失败。

TypeError代表作用域判别成功,但是对结果的操作是非法或者不合理的。

例如:

代码语言:javascript
复制
foo();
var foo = function () {
     console.log('a');
}

执行foo()语句时,首先RHS查找,在全局作用域中找到foo变量,值为undefined(变量提升)。

然后以函数执行方式操作foo变量,很明显,undefined并不是一个合法函数,于是引擎抛出异常:Uncaught TypeError: foo is not a function,执行失败。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-05-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. LHS(left-hand-side左查找)和RHS(right-hand-side右查找)
  • 2. LHS和RHS查询区别
  • 3. 小贴士
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档