js笔记-引用类型

2020-09-19  本文已影响0人  quanCN

引用类型

Object类型
Array类型

ECMAScript数组同其他语言一样都是数据的有序列表,ECMAScript数组的每一项可以保存任何类型的数据,而且ECMAScript数组的大小是可以动态调整的,即可以随着数据的添加自动增长以容纳新增数据

Function类型

函数实际上是对象,每个函数都是Function类型的实例,而且都与其他引用类型一样具有属性和方法。

//函数声明
function sum(num1,num2) {
    return num1+num2;
}
console.log(sum(1,2));//3
//函数表达式
var sum = function (num1,num2) {
    return num1+num2;
}
console.log(sum(1,2));//3
var sum = new Function("num1","num2","return num1+num2");
console.log(sum(1,2));//3

由于函数名仅仅是指向函数的指针,因此函数名与包含对象指针的其他变量没有什么不同。换句话说,一个函数可能会有多个名字

function sum(num1,num2) {
    return num1+num2;
}
console.log(sum(1,2));
var sum1 = sum;
console.log(sum1(1,2));
sum = null;
console.log(sum1(1,2));
基本包装类型

为了方便便于操作基本类型值,ECMAScript还提供了3个特殊的引用类型:Boolean、Number、String。这些类型与其他引用类型相似,但同时也具有与各自的基本类型相应的特殊行为。实际上,每当读取一个基本类型值的时候,后台就会创建一个对应的基本包装类型的对象,从而让我们能够调用一些方法来操作这些数据。

var s1 = "some text";
var s2 = s1.substring(2);

当第二行代码访问s1时,访问过程处于一种读取模式,也就是要从内存中读取这个字符串的值,而在读取模式中访问字符串时,后台都会自动完成下列处理

  1. 创建String类型的一个实例
  2. 在实例上调用指定的方法
  3. 销毁这个实例

相当于解释器完成了如下代码

var s1 = new String("some text");
var s2 = s1.substring(2);
s1 = null;

:引用类型与基本包装类型的主要区别就是对象的生存期。使用new操作符创建的引用类型的实例,在执行流离开当前作用域之前都一直保存在内存中。而自动创建的基本包装类型的对象,则只存在于一行代码的执行瞬间,然后立即被销毁

单体内置对象
上一篇 下一篇

猜你喜欢

热点阅读