欢迎光临 - 我的站长站,本站所有资源仅供学习与参考,禁止用于商业用途或从事违法行为!

js教程

ECMAScript原始值和引用值说明

js教程 我的站长站 2021-08-06 共70人阅读

原始值和引用值

ECMAScript变量可以包含两种不同类型的数据:原始值和引用值。原始值(primitive value)就是最简单的数据,引用值(reference value)则是由多个值构成的对象。

在把一个值赋给变量时,JavaScript引擎必须确定这个值是原始值还是引用值。

原始值

Undefined,Null,Boolean,Number,String和Symbol。保存原始值的变量是按值(by value)访问的,因为我们操作的就是存储在变量中的实际值。

引用值

引用值是保存在内存中的对象。与其他语言不同,JavaScript不允许直接访问内存位置,因此也就不能直接操作对象所在的内存空间。在操作对象时,实际上操作的是该对象的引用(reference)而非实际的对象本身。为此,保存引用值的变量时按引用(by reference)访问的。

注意,在很多语言中,字符串是使用对象表示的,因此被认为是引用类型。ECMAScript打破了这个惯例。

动态属性

原始值和引用值的定义方式很类似,都是创建一个变量,然后给它赋一个值。不过,在变量保存了这个值之后,可以对这个值做什么,则大有不同。对于引用值而言,可以随时添加,修改和删除其属性和方法。比如,看下面的示例:

let person = new Object()
person.name = '何小生'console.log(person.name)    // "何小生"

这里,首先创建了一个对象,并把它保存在变量person中。然后,给这个对象添加了一个名为name的属性,并给这个属性赋值了一个字符串何小生.在此之后,就可以访问这个新属性,直到对象被销毁或属性被显式的删除。

原始值不能有属性,尽管尝试给原始值添加属性不会报错,例如:

let name = '何小生'name.age = 26console.log(name.age)   // undefined

在此,代码想给字符串name定义一个age属性,并给该属性赋值26,紧接着在下一行,属性不见了。记住,只有引用值可以动态天价后面可以使用的属性。

注意,原始类型的初始化可以只使用原始字面量形式。如果使用的是new关键字,则JavaScript会创建一个Object类型的实际,但其行为类似原始值。下面来看看这两种初始化方式的差异:

let name1 = '何小生'let name2 = new String('小何')
name1.age = 26name2.age = 27console.log(name1.age)    // undefinedconsole.log(name2.age)    // 27console.log(typeof name1) // stringconsole.log(typeof name2) // object

复制值

除了存储方式不同,原始值和引用值在通过变量复制时也有所不同。在通过变量把一个原始值赋值到另一个变量时,原始值会被复制到新变量的位置。请看下面的例子:

let num1 = 5const num2 = num1

这里,num1包含数值5。当把num2初始化为num1时,num2也会得到数值5。这个值跟存储在num1中的5是完全独立的,因为它是那个值的副本。

这两个变量可以独立使用,互不干扰。这个过程如图所示:

在把引用值从一个变量赋给另一个变量时,存储在变量中的值也会被复制到新变量所在的位置。区别在于,这里复制的值实际上是一个指针,它指向存储在堆内存中的对象。操作完成后,两个变量实际上指向同一个对象,因此一个对象上面的变化会在另一个对象上反应出来,如下面的例子所示:

let obj1 = new Object()let obj2 = obj1
obj1.name = '何小生'console.log(obj2.name)   // '何小生'

值已经被复制了

在这个例子中,变量obj1保存了一个新对象的实例。然后,这个值被复制到obj2,此时两个变量都指向了同一个对象。在给obj1创建属性name并赋值后,通过obj2也可以访问这个属性,因为它们都指向同一个对象。

如图,展示了变量与堆内存中对象之间的关系

相关推荐
  • js字符串
  • js删除
  • js删除字符串最后一个逗号方法

    js删除字符串最后一个逗号方法,可以使用以下几种实现方法:方法一:正则表达式let str = "a,b,c,d,";str = str.replace(/,$/, '');console.log(str); // 输出:a,b,c,d这里使用正则表达式 /,$/ 匹配到最后一个逗号,并将其替换为空字符串。方法二:sli...

    js教程 73 1个月前
  • js语言!=与!==的区别

    != (不等于)!= 是松散的不等于运算符。它在比较两个值时,会先进行类型转换(type coercion),然后再比较值是否不相等。如果两个值在类型转换后不相等,则返回 true,否则返回 false。例如:5 != '5' // false,因为 '5' 会被转换成数字 5,然后 ...

    js教程 97 2个月前
  • Hexo插件开发实战教程

    Hexo的插件嵌入有两种方式,一种是通过脚本(Scripts)的方式引入,一种是通过插件(Packages)的方式将自定义的插件内容发布到npm上。本文主要介绍第二种,如果您的代码很简单,建议您编写脚本,您只需要把 JavaScript 文件放到主题目录的 scripts 文件夹,在启动时就...

    js教程 11 3个月前
  • js截取字符串教程

    slice()方法接受两个参数,起始索引和结束索引(可选)。它返回从起始索引到结束索引(不包括结束索引)之间的子字符串。let str = 'Hello, World!';let result = str.slice(7, 12); // 截取从索引7到索引12之前的字符console.log(result); // 输出 "...

    js教程 31 11个月前
  • JavaScript随机生成指定范围或指定类型的随机数

    生成指定范围随机数1、使用 random() 方法可以返回一个介于 0 ~ 1 之间的伪随机数(包括 0,不包括 1)。Math.random()下面是一个测试样例var random = Math.random();console.log(random);2,生成 [ n, m ) 范围内的随机数(大于等于n,小于m)这种最简单,因为和 ...

    js教程 43 1年前
  • js删除字符串最后一个逗号方法

    js删除字符串最后一个逗号方法,可以使用以下几种实现方法:方法一:正则表达式let str = "a,b,c,d,";str = str.replace(/,$/, '');console.log(str); // 输出:a,b,c,d这里使用正则表达式 /,$/ 匹配到最后一个逗号,并将其替换为空字符串。方法二:sli...

    js教程 73 1个月前
  • JavaScript定时删除指定元素方法

    JavaScript定时删除指定元素一般用到自动隐藏的效果功能上面,主要用到了JS的setTimeout语法。下面是一个定时五秒的DOM中删除示例:// 获取当前脚本的父元素var currentScript = document.currentScript;var parent = currentScript.parentNode;// 从DO...

    js教程 19 3个月前
  • 如何新建修改删除cookie

    加载js库我们需要准备两个js库,一个是jquery.js,另一个是jquery.cookie.js这两个js库<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script> <script type="text/javascript" src="js/jquery.cookie.js"></script>使用方法新添cooki...

    js教程 13 5个月前
  • Gridstack.js交互式仪表板Typescript库
    Gridstack.js交互式仪表板Typescript库

    项目介绍Gridstack.js是一个专注交互式仪表板Typescript库,用于仪表板布局和创建,只需几行代码就可以帮助开发人员 创建漂亮的可拖动、可调整大小、响应式布局。非常合适做一些可视化页面布局,让用...

    js教程 26 6个月前
  • JavaScript限制右键+F12弹窗提示效果

    一段简单的JavaScript限制右键+F12弹窗提示效果,复制过去就可以直接使用,无需修改代码。效果:在网页内如果鼠标右键或者按F12,浏览器就会弹出窗口,弹出的文字可以自己修改。代码如下:<script language="javascript"> function click() { if ...

    js教程 44 1年前