我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何理解Javascript的连续赋值运算

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何理解Javascript的连续赋值运算

这篇文章将为大家详细讲解有关如何理解Javascript的连续赋值运算,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

小编将分享一下作者在写Javascript的心得,是关于连续赋值运算一些技巧。对大家在Web开发方面肯定有很大的启发和帮助。

一、引子

var a = {n:1};     a.x = a = {n:2};     alert(a.x); // --> undefined

这是蔡蔡在看jQuery源码 时发现这种写法的。以上第二句 a.x = a = {n:2} 是一个连续赋值表达式。这个连续赋值表达式在引擎内部究竟发生了什么?是如何解释的?

  二、猜想

猜想1:从左到右赋值,a.x 先赋值为{n:2},但随后 a 赋值为 {n:2},即 a 被重写了,值为 {n:2},新的 a 没有 x属性,因此为undefined。步骤如下

a.x = {n:2};   a = {n:2};

这种解释得出的结果与实际运行结果一致,貌似是对的。注意猜想1中 a.x 被赋值过。

猜想2:从右到左赋值,a 先赋值为{n:2},a.x 发现 a 被重写后(之前a是{a:1}),a.x = {n:2} 引擎限制a.x赋值,忽略了。步骤如下:

a = {n:2};  a.x 未被赋值{n:2}

等价于 a.x = (a = {n:2}),即执行了***步,这样也能解释a.x为undefined了。注意猜想2中a.x压根没被赋值过。

  三、证明

上面两种猜想相信多数人都有,群里讨论呆呆认为是猜想1, 我认为是猜想2。其实都错了。我忽略了引用的关系。如下,加一个变量b,指向a。

Js代码

var a = {n:1};     var b = a; // 持有a,以回查     a.x = a = {n:2};     alert(a.x);// --> undefined     alert(b.x);// --> [object Object]

发现a.x仍然是undefined,神奇的是 b.x 并未被赋值过(比如:b.x={n:2}),却变成了[object Object]。b 是指向 a({n:1})的,只有a.x = {n:2}执行了才说明b是有x属性的。实际执行过程:从右到左,a 先被赋值为{n:2},随后a.x被赋值{n:2}。

a = {n:2};  a.x = {n:2};

等价于

a.x = (a = {n:2});

  与猜想2的区别在于a.x 被赋值了,猜想2中并未赋值。最重要的区别,***步 a = {n:2} 的 a 指向的是新的对象{n:2} , 第二步 a.x = {n:2} 中的 a 是 {a:1}。即在这个连等语句

Js代码

a.x = (a = {n:2});

a.x 中的a指向的是 {n:1},a 指向的是 {n:2}。如下图

如何理解Javascript的连续赋值运算

  四:解惑

这篇写完,或许部分人看完还是晕晕的。因为里面的文字描述实在是绕口。最初我在理解这个连等赋值语句时

Js代码

var a = {n:1};     a.x = a = {n:2};

认为引擎会限制a.x的重写(a被重写后),实际却不是这样的。指向的对象已经不同了。引擎也没有限制a.x={n:2}的重写。

谢谢所有参与讨论的人:蔡蔡、猪大肠 、呆呆、雅儒。这个问题最早是蔡蔡提出的。雅儒在 菜鸟灰呀灰 群里每次的讨论都那么投入,认真,哪怕是别人提出的话题。

五:结束

呵,以另一个连续赋值题结束。fun执行后,这里的 变量 b 溢出到fun外成为了全局变量。想到了吗?

Js代码

function fun(){         var a = b = 5;     }     fun();     alert(typeof a); // --> undefined     alert(typeof b); // --> number

关于如何理解Javascript的连续赋值运算就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何理解Javascript的连续赋值运算

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

c语言连续赋值如何计算

在C语言中,连续赋值的计算顺序是从右向左进行的。也就是说,右边的表达式会先计算,然后将结果赋值给左边的变量。例如:int a, b, c;a = b = c = 5;在上面的代码中,先计算`c = 5`,然后将结果赋值给`b`,再将
2023-10-27

如何理解JavaScript原型链和instanceof运算符的关系

如何理解JavaScript原型链和instanceof运算符的暧昧关系,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。时间回到两个月前,简单地理了理原型链、prototype以
2023-06-17

如何理解Python的二元算术运算

本篇内容介绍了“如何理解Python的二元算术运算”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!查看 C 代码按照惯例,我们从查看 CPyt
2023-06-16

MySQL 中的比较运算符如何处理日期值?

日期之间的比较运算符将以合乎逻辑的方式工作。在下面的示例中,在比较两个日期时,MySQL 只是比较两个数字或字符串 -mysql> select 20171027 < 20150825;+-------------------------
2023-10-22

如何理解C ++中的范围解析运算符

本篇内容介绍了“如何理解C ++中的范围解析运算符”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.当存在具有相同名称的局部变量时,要访问全
2023-06-16

如何理解linux中的数值计算的语言

这篇文章主要介绍“如何理解linux中的数值计算的语言”,在日常操作中,相信很多人在如何理解linux中的数值计算的语言问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何理解linux中的数值计算的语言”的疑
2023-06-13

如何理解VB.NET串联运算符的两种应用方式

今天就跟大家聊聊有关如何理解VB.NET串联运算符的两种应用方式,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。我们今天先来了解一下VB.NET串联运算符的相关应用技巧,提高自己对这门
2023-06-17

加法、减法、乘法和除法运算符如何处理 MySQL 表中存储的日期值?

当我们尝试对表中存储的日期值进行此类操作时,MySQL 会将日期值假设为数字并执行算术运算。假设我们有一个名为“example”的表在“orderdate”列中有一个日期值,然后进行算术运算将澄清上述内容 -mysql> select *
2023-10-22

编程热搜

目录