JS中const对于复杂类型变量和普通类型变量的区别详解

 更新时间:2023年11月05日 08:38:45   作者:悲伤周杰伦  
我们在开发的过程中一定常常发现const关键字定义的简单类型变量不可以改变,但是你如果定义的是一个复杂类型变量(比如对象)的话对里面属性的增删改查是可以的,那这又是为什么呢,接下来就来和小编一起探讨一下吧

const关键字是让什么不能变?

const实际上的不能变并不是说变量的值不能变,而是初始化后变量所指向在栈中的内存上的数据不能变

我们先切记这一点先,看下文!!!

js中变量的两种类型

js中的变量类型可以分为两种:

  • 简单数据类型

    Number

    String

    Boolean

    Undefined

    null

    symbol

  • 复杂数据类型(下面我都称为对象)

    Object

    Array

    Function(函数实际上是对象)

两种类型的的存储区别

都是两种数据结构,靠他们来给变量分配使用内存

js的两种数据类型的变量即是存储在堆和栈中

简单类型变量的存储

这种类型的变量我们是用得最多的

它是存储在栈中而已

以下是的示例定义

var num=100
var bool=false
var str='字符串

而他在栈中的存储可以形象比喻为这样子

其中变量的值存储在变量指向的栈中的内存地址上,看上图,100就是存储在内存地址上

结合上面所说的const的作用就知道为什么const关键字定义的简单类型的变量的值不能变,因为改变其变量的值是直接改变变量指向的内存上的数据,这是const关键字不允许的

那为什么复杂类型的又可以呢,看下文

复杂类型变量的存储

先说一下,复杂类型的值的更改指的是

复杂类型变量里属性可以更改,整个对象的更改const关键字是不允许的!!!

比如

const ob={
a:100,
b:200
}
const ob1={
c:100
}
ob.a=200         //   successful ! ! !
ob=ob1           //   fail ! ! !

如果需要替换整个对象,const关键字是不允许的,但是属性值的更改是可以的

那这又是为什么 ? 看下面

我们先要记住const关键字是不允许更改变量的哪个地方,是变量在栈中存储变量值的内存地址上的值

对,没错 !!!这也是普通变量值不能更改的原因

但是为什么复杂变量的可以更改呢,但是不可以替换呢

主要原因是:

复杂变量的值不是存储在栈中,而是存储在堆里,复杂变量在栈中内存上的值是指向存储该复杂类型变量值的堆上的地址

如果这句话看不懂的话,可以看下图

所以更改对象的属性值是更改在堆上的值,而替换对象则是要更改存储在栈中内存地址上变量在堆上存储数据的地址值,而这个更改恰恰是const关键字不允许的!!!

这也是为什么会有对象的浅拷贝和深拷贝的原因,因为你把一个对象直接赋值给另一个对象,准确来说是把对象变量在栈中的存储的指向改变了,指向了同一个在堆里存储的数据,所以你改变其中一个变量的值,会造成其堆上存储的数据改变,所以另外一个对象的值也会改变,这就是为啥会有浅拷贝!!!

以上就是JS中const对于复杂类型变量和普通类型变量的区别详解的详细内容,更多关于JS const复杂类型和普通类型变量区别的资料请关注脚本之家其它相关文章!

相关文章

  • JavaScript中的冒泡排序法

    JavaScript中的冒泡排序法

    这篇文章主要介绍了JavaScript中的冒泡排序法的知识,并通过一个例子给大家讲解了js冒泡排序,非常不错,具有参考借鉴价值,感兴趣的朋友一起学习吧
    2016-08-08
  • JavaScript在IE和Firefox浏览器下的7个差异兼容写法小结

    JavaScript在IE和Firefox浏览器下的7个差异兼容写法小结

    尽管那需要用长串的、沉闷的不同分支代码来应付不同浏览器的日子已经过去,偶尔还是有必要做一些简单的区分和目标检测来确保某块代码能在用户的机器上正常运行。
    2010-06-06
  • JavaScript 获取任一float型小数点后两位的小数

    JavaScript 获取任一float型小数点后两位的小数

    这篇文章主要介绍了JavaScript如何获取小数任一小数点后的位数的小数,需要的朋友可以参考下
    2014-06-06
  • 邮箱下拉自动填充选择示例代码附图

    邮箱下拉自动填充选择示例代码附图

    这篇文章主要介绍了邮箱下拉自动填充选择的具体实现,需要的朋友可以参考下
    2014-04-04
  • JavaScript匿名函数之模仿块级作用域

    JavaScript匿名函数之模仿块级作用域

    这篇文章主要介绍了JavaScript匿名函数之模仿块级作用域的相关资料,需要的朋友可以参考下
    2015-12-12
  • JavaScript实现图片上传并预览并提交ajax

    JavaScript实现图片上传并预览并提交ajax

    这篇文章主要为大家详细介绍了JavaScript实现图片上传并预览并提交ajax,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-09-09
  • 微信小程序实现录音Record功能

    微信小程序实现录音Record功能

    这篇文章主要为大家详细介绍了微信小程序实现录音Record功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-05-05
  • coffeescript使用的方式汇总

    coffeescript使用的方式汇总

    而来到CoffeeScript的世界,美妙故事再次上演。在写了几行代码后我相信你将不会再想念原生的Javascript了。CoffeeScript包含了许多新特性,当将它与jQuery,node.js,javascript结合时,你会发现一片新天地。
    2015-08-08
  • ES6 javascript的异步操作实例详解

    ES6 javascript的异步操作实例详解

    这篇文章主要介绍了ES6 javascript的异步操作,结合实例形式分析了ES5中异步操作的概念、原理、使用方法及相关注意事项,需要的朋友可以参考下
    2017-10-10
  • javascript手风琴下拉菜单实现代码

    javascript手风琴下拉菜单实现代码

    手风琴效果的下拉菜单大家都有见到过吧,实现的方法也有很多,这篇文章就为大家分享了javascript手风琴下拉菜单实现代码,纯手写的,感兴趣的朋友不要错过。
    2015-11-11

最新评论