JS的变量类型:基本类型和引用类型

小咪咪 2022-05-30 04:53 365阅读 0赞

基本数据类型:按值访问,可操作保存在变量中的实际的值。基本类型值指的是简单的数据段。

基本数据类型有这五种:Undefined、Null、String、Number、Boolean。

引用类型:当复制保存着对象的某个变量时,操作的是对象的引用,但在为对象添加属性时,操作的是实际的对象。引用类型值指那些可能为多个值构成的对象。

引用类型有这几种:object、Array、RegExp、Date、Function、特殊的基本包装类型(String、Number、Boolean)以及单体内置对象(Global、Math)。

对于基本类型值和引用类型值的区别:

  1. 引用类型值可添加属性和方法,而基本类型值则不可以。

复制代码

  1. //为引用类型值添加属性
  2. var p = new Object();
  3. p.age=11;
  4. alert(p.age);//11
  5. //为基本类型值添加属性
  6. var name = 'a';
  7. name.age = 11;
  8. alert(name.age); //undefined

复制代码

② 在复制变量值时,基本类型会在变量对象上创建一个新值,再复制给新变量。此后,两个变量的任何操作都不会影响到对方;而引用类型是将存储在变量对象的值复制一份给新变量,但是两个变量的值都指向存储在堆中的一个对象,也就是说,其实他们引用了同一个对象,改变其中一个变量就会影响到另一个变量。

  1. //基本类型值
  2. var a = 'a';
  3. var b = a;
  4. a = 'b';
  5. alert(b); //a

引用类型值,以数组为例:

复制代码

  1. //引用类型值,以数组为例
  2. //1.对其中一个变量直接赋值不会影响到另一个变量(并未操作引用的对象)
  3. var a = [1,2,3];
  4. var b = a;
  5. a = [1,2,3,4];
  6. alert(a);//1,2,3,4
  7. alert(b); //1,2,3
  8. //2.使用push(操作了引用的对象)
  9. var a = [1,2,3];
  10. var b = a;
  11. a.push(4);
  12. alert(a);//1,2,3,4
  13. alert(b); //1,2,3,4

复制代码

传递参数:按值传递,将函数外部的值复制给函数内部的参数(一个局部变量),当对局部变量进行操作时,局部变量的变化会反应在函数外部,但是这并不会影响函数外部的值。

复制代码

  1. function add(a){
  2. a += 10;
  3. return a;
  4. }
  5. var num = 10;
  6. var result = add(num);
  7. alert(num); //10
  8. alert(result); //20

复制代码

当然,使用对象时可能会不好理解:

  1. function setName(obj){
  2. obj.name = 'a';
  3. }
  4. var p = new Object();
  5. setName(p);
  6. alert(p.name); //a

明明参数是按值传递的,为什么创建的p实例也能获取到在setName()中添加的name属性呢?

因为obj和p引用的是同一个对象,即便按值传递,obj也会按引用来访问同一个对象。看一下下面的例子就能清楚了。

复制代码

  1. function setName(obj){
  2. obj.name = 'a';
  3. obj = new Object();
  4. obj.name = 'a';
  5. return obj;
  6. }
  7. var p = new Object();
  8. var p2 = setName(p);
  9. alert(p.name); // a
  10. alert(p2.name); // b

复制代码

在函数内部重写obj对象,此时obj对象引用的是一个局部对象,外部的p还是原始的引用,因此不会改变。

检测类型:

typeof:确定变量是字符串、数值、布尔值还是undefined的最佳工具。

复制代码

  1. var num = 1;
  2. var a = 'a';
  3. var b;
  4. var flag = true;
  5. var o = null;
  6. alert(typeof num); //number
  7. alert(typeof a); //string
  8. alert(typeof b); //undefined
  9. alert(typeof flag); //boolean
  10. alert(typeof o); //object

复制代码

instanceof :判断是否是某个对象类型。

  1. var a = [1,2,3];
  2. alert(a instanceof Object); //true
  3. alert(a instanceof Array); //true
  4. alert(a instanceof RegExp); //false

发表评论

表情:
评论列表 (有 0 条评论,365人围观)

还没有评论,来说两句吧...

相关阅读

    相关 JS基本类型引用类型

    JS 中基本类型和引用类型值 引入概念:基本类型和引用类型 1、可以感受到,JS 的变量及其松散,那么,正是 JS 变量松散 的本质,决定了:JS 变量名只是 一个在特定...