iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > node.js >如何理解Javascript的连续赋值运算
  • 459
分享到

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

2024-04-02 19:04:59 459人浏览 安东尼
摘要

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

这篇文章将为大家详细讲解有关如何理解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的连续赋值运算就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: 如何理解Javascript的连续赋值运算

本文链接: https://www.lsjlt.com/news/86501.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 如何理解Javascript的连续赋值运算
    这篇文章将为大家详细讲解有关如何理解Javascript的连续赋值运算,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。小编将分享一下作者在写Javascrip...
    99+
    2024-04-02
  • c语言连续赋值如何计算
    在C语言中,连续赋值的计算顺序是从右向左进行的。也就是说,右边的表达式会先计算,然后将结果赋值给左边的变量。 例如: int a, ...
    99+
    2023-10-27
    c语言
  • JavaScript 中如何使用逻辑赋值运算符
    本篇文章为大家展示了JavaScript 中如何使用逻辑赋值运算符,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。无条件 vs 有条件数学运算符,例如 +是无条件的。...
    99+
    2024-04-02
  • javascript的赋值运算符有哪些
    这篇文章主要介绍“javascript的赋值运算符有哪些”,在日常操作中,相信很多人在javascript的赋值运算符有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”ja...
    99+
    2024-04-02
  • PHP中连接赋值运算符的用法
    这篇文章主要讲解了“PHP中连接赋值运算符的用法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP中连接赋值运算符的用法”吧!说明当我们使用连接赋值运算符(.=)之后,变量存储的值就发生改...
    99+
    2023-06-20
  • JavaScript有哪些常见的赋值运算符
    这篇文章主要介绍了JavaScript有哪些常见的赋值运算符,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。JavaScript常见赋值运算符...
    99+
    2024-04-02
  • python中赋值运算符如何使用
    python中赋值运算符如何使用,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。说明赋值运算符的左侧可以是所有元素都是变量的元组或列表,从而同时赋值多个变量。可以在赋值运算符左侧...
    99+
    2023-06-20
  • 如何理解JavaScript运算符
    这篇文章主要介绍“如何理解JavaScript运算符”,在日常操作中,相信很多人在如何理解JavaScript运算符问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何理解Ja...
    99+
    2024-04-02
  • js如何使用逻辑赋值运算符
    这篇文章主要介绍js如何使用逻辑赋值运算符,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!逻辑赋值运算符逻辑赋值运算符是由逻辑运算符&&、||、和赋值运算符=组合而成。const a ...
    99+
    2023-06-27
  • mysql如何生成连续日期及变量赋值
    这篇文章主要介绍了mysql如何生成连续日期及变量赋值,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、生产连续日期说明:主要作用于一些统计数据,来根据时间顺序进行显示;假如...
    99+
    2023-06-29
  • c语言的连续赋值问题怎么解决
    C语言的连续赋值问题是指在一条语句中连续赋值多个变量时可能会出现的问题。例如: int a, b; a = b = 10; 在这个例...
    99+
    2023-10-27
    c语言
  • PHP中连接赋值运算符的概念及用法
    这篇文章主要介绍“PHP中连接赋值运算符的概念及用法”,在日常操作中,相信很多人在PHP中连接赋值运算符的概念及用法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP中连接赋值运算符的概念及用法”的疑惑有所...
    99+
    2023-06-20
  • ES6 解构赋值的原理及运用
    目录数组的解构赋值对象的解构赋值解构赋值的运用交换变量的值从函数返回多个值遍历Map结构函数参数的解构赋值数组的解构赋值 let [a, b, c] = [1, 2, 3] ...
    99+
    2024-04-02
  • 如何理解javascript三目运算符
    这篇文章主要介绍“如何理解javascript三目运算符”,在日常操作中,相信很多人在如何理解javascript三目运算符问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何...
    99+
    2024-04-02
  • JavaScript如何使用空值合并运算符
    这篇文章主要为大家展示了“JavaScript如何使用空值合并运算符”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript如何使用空值合并运算符”这篇文章吧。空值合并运算符 '...
    99+
    2023-06-27
  • Python如何使用三元运算符进行条件赋值
    本篇内容介绍了“Python如何使用三元运算符进行条件赋值”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!技巧1 就地交换两个数字Python...
    99+
    2023-06-29
  • JavaScript ES6解构运算符的理解和运用
    目录前言解构符号的作用使用方法解构赋值的应用浅谈应用提取json数据可扩展运算符...交换变量值总结前言 最近一直在学JavaScript,看到了ES6中的解构符号,觉得这个给我们...
    99+
    2024-04-02
  • 如何在Javascript中使用解构赋值语法
    本篇文章给大家分享的是有关如何在Javascript中使用解构赋值语法,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。前言首先在 ES6中引入的“解构赋值语法”允许把数组和对象中...
    99+
    2023-06-14
  • 如何理解ajax struts2 下拉框赋值
    这篇文章给大家介绍如何理解ajax struts2 下拉框赋值,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 1.此代码适合所有下拉列表取值 2.一个项目...
    99+
    2024-04-02
  • python如何运算输入的值
    在Python中,可以使用input()函数来获取用户的输入值。输入的值默认为字符串类型,如果需要进行数值运算,需要使用int()或...
    99+
    2023-09-29
    python
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作