在 JavaScript 在编程中,或者更确切地说,变量是计算机内存中存储数据的位置。根据语言,可以立即或稍后分配一个值。然后可以在程序中稍后引用变量,而不是再次明确说明相同的值。
在 JavaScript 数据以值的形式传输,这些值可以是原始值或对象值。作为一个人 JavaScript 开发人员,了解 JavaScript 拥有坚实的语言基础,如何处理数据至关重要。
原始值包括:
另一方面,对象值为:
立即学习“Java免费学习笔记(深入);
这些值类型在传输过程中表现不同,请考虑以下代码片段:
var myName = "Fred";
var otherName = myName;
myName =“阿什利”;
console.log(我的名字); //阿什利
console.log(其他名称); //弗雷德
请注意,otherName 保持不变,尽管它看起来像 myName “副本”。事实上,实际情况是,当 otherName 被分配给 myName 它没有被分配成字符串“Fred副本,但创建了一个新字符串“Fred”。因此,myName 和 otherName 两者之间没有直接链接。这就是 JavaScript 传递原始值的方式。
对象值的处理方法不同,请参见以下代码片段:
var myObj = {颜色:“红色”};
var otherObj = myObj;
myObj.color = "蓝色";
console.log(myObj.color); //蓝色
console.log(otherObj.color); //蓝色
在这里,创建对象并分配给它 myObj,然后分配给它 otherObj,看看如何只通过改变 myObj 改变颜色属性 otherObj 和 myObj 颜色属性。这是因为对象值作为引用传递。 myObj 不直接引用对象,而是引用对象,然后引用对象 otherObj 分配给 myObj,它是对真实对象的引用。因此,两个变量都与相同的对象相连,因为它们指向相同的引用,其中一个变量的变化会影响另一个变量。
这就是为什么两个对象的比较(===)直接返回 false,你们实际上是在比较两个不同的引用。在这里, myObj === otherObj 返回 true,因为我们正在引用相同的参考。
希望这能让你对 JavaScript 如何在幕后工作有一个全新的视角。
在此之前,请保持没有错误。
以上是JavaScriptt 请关注其他相关文章,了解更多关于值和引用的细节!
JavaScript 值与引用-js教程
远程连接计算机,命名技巧大揭秘!
Typescript 编码年史:花-js教程可以放置
Efficient & Secure Backup & Restoration Guide
长时间中断后重新开始编码-js教程
Redux VS Redux 工具包 && Redux Thunk VS Redux-Saga-js教程
远程桌面连接迟缓,亟待优化提速!
Typescript 编码年史:花-js教程可以放置
长时间中断后重新开始编码-js教程
Redux VS Redux 工具包 && Redux Thunk VS Redux-Saga-js教程
比较 Python Python教程中的模块化和输入处理(带代码示例)
Go 对比框架的异步编程能力-Golang
从 TypeScript 到 Golang:后端之旅更顺畅-Golang
Go 并发和协程场景中框架的性能-Golang
用于Web开发的C 框架与C 库-C
哪种C 支持跨平台移动开发的框架?-C
C 框架和C 对比图书馆的学习曲线-C
哪种C 最适合开发游戏移动应用的框架?-C
Golang框架的生态系统支持云原生开发所需的技术吗?-Golang