JS中基本类型和引用类型分别指的是什么?有何区别?

大家好,我是IT修真院的学员,一枚正直纯洁善良的web前端程序员

今天给大家分享一下基本类型和引用类型分别指的是什么?有何区别??

1.背景介绍

先了解一下 JAVASCRIPT 是什么

JavaScript是一种属于网络的脚本语言,已经被广泛用于Web应用开发,常用来为网页添加各式各样的动态功能, 为用户提供更流畅美观的浏览效果。JavaScript可以嵌入在 HTML 中,或者作为单独的文件被 HTML 引用, 用以实现某种动态的功能。

ECMAScript数据类型

ECMAScript是JavaScript在语法和语义上的标准、规范。JavaScript是基于ECMAScript标准实现的。 Javascript包括ECMAScript、DOM、BOM。 在日常场合,这两个词是可以互换的。

在 ECMAScript 规范中,共定义了 7 种数据类型,

Number:包含整数和浮点数

String:字符串用双引号或者单引号,有length属性

Boolean:只有true和false两个值

Null:被看作是空的对象引用,只有一个值,null

Undefined:未定义

Symbol:表示独一无二的值

Object:对象

2、知识剖析

ECMAScript数据类型分为基本类型和引用类型两大类 (简单点说就是拥有方法的类型和不能拥有方法的类型)

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

基本类型:number,string,boolean,null,undefined

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

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

3、常见问题

基本类型和引用类型的不同之处有哪些

4、解决方案

基本类型的值是不可变的,引用类型的值是可变的;

基本类型的变量是存放在栈区的(栈区指内存里的栈内存),引用类型的值是同时保存在栈内存和堆内存中的对象;

基本类型的比较是值的比较,引用类型的比较是引用的比较;

1-1、基本类型的值是不可变的:

任何方法都无法改变一个基本类型的值,比如一个字符串:

                          var name = "mary";

                          name.toUpperCase(); //"MARY"

                          console.log(name); //"mary"

                          var person = "mary";

                          person.age = 22;

                          person.method = function () {

                                    return 100;

                            };

                          console.log(person.age);//undefined

                          console.log(person.method);//提示错误


第一个例子:会发现原始的name并未发生改变,而是调用了toUpperCase()方法后返回的是一个新的字符串。

第二个例子:我们不能给基本类型添加属性和方法。

1-2、引用类型的值是可变的:

我们可为引用类型添加属性和方法,也可以删除其属性和方法

                            var person = {};

                            person.name = 'jozo';

                            person.age = 22;

                            person.sayName = function(){console.log(person.name);}

                            person.sayName();// 'jozo'

                            delete person.name; //删除person对象的name属性

                            person.sayName(); // undefined


上面代码说明引用类型可以拥有属性和方法,并且是可以动态改变的。

2-1、基本类型的变量是存放在栈区的(栈区指内存里的栈内存)

假如有以下几个基本类型的变量:

                        var name = 'jozo';

                        var city = 'guangzhou';

                        var age = 22;


2-2、引用类型的存储需要内存的栈区和堆区(堆区是指内存里的堆内存)共同完成, 栈区内存保存变量标识符和指向堆内存中该对象的指针, 也可以说是该对象在堆内存的地址。

                            var person1 = {name:'jozo'};

                            var person2 = {name:'xiaom'};

                            var person3 = {name:'xiaoq'};


3-1、基本类型的比较是值的比较

只有在它们的值相等的时候它们才相等。

                            var a = 1;

                            var b = true;

                            console.log(a == b);//true


在用==比较两个不同类型的变量时会进行一些类型转换。像上面的比较先会把true 转换为数字1再和数字1进行比较,结果就是true了。

3-2、引用类型的比较是引用的比较

                            var person1 = {};

                            var person2 = {};

                            console.log(person1 == person2); // false


引用类型是按引用访问的,换句话说就是比较两个对象的堆内存中的地址是否相同,那很明显, person1和person2在堆内存中地址是不同的

5、编码实战

6、扩展思考

基本类型和引用类型分别是怎么传递参数的?

基本数据类型传递参数

                     function addTen(num){

                        num+=10;

                        return num;

                    }

                    var count=20;

                    var result=addTen(count);

                    console.log(count);

                      console.log(result);


 执行结果是:20和30。在这段代码中,将变量count当做参数传递给了函数addTen, 也就是相当于将变量count的值复制给了函数addTen的参数。这时addTen的参数num可以看做是函数内部的一个变量。 在上段代码中,就相当于两个基本数据类型变量之间的值复制。而基本数据类型都有自己独立的内存地址, 所以num和count是没有任何关系的,他们只是值相等而已,函数执行完毕后,count的值并没有改变。 而函数外面的result是被直接赋值的,所以result的值就是函数的结果30。

引用类型传递参数

                         function setName(obj){

                      obj.name="LSN";

                        }

                        var person=new Object();

                        setName(person);

                        console.log(person.name);//LSN


执行结果是:LSN。在这段代码中,函数setName的作用是给obj对象添加了一个属性name并给该属性赋值为"LSN", 因为obj是引用类型,所以这里属于是将引用类型person赋值给了obj,也就是说person和obj引用了一个内存地址, 所以当给obj新加了属性name时,在函数外面的person也跟着改变,最后person.name的结果为LSN。

7、参考文献

参考一:js基本类型和引用类型的区别

参考二:W3school

参考三:指针的理解

8、更多讨论

两种类型的检测方法是什么

答:Typeof操作符是检测基本类型的最佳工具

                        var num = 1;

                        var a = 'a';

                        var b;

                        var flag = true;

                        var c = null;

                        alert(typeof num); //number

                        alert(typeof a); //string

                        alert(typeof b); //undefined

                        alert(typeof flag); //boolean

                        alert(typeof c); //object


instanceof :判断是否是某个引用类型。

                        var a = [1,2,3];

                        alert(a instanceof Object); //true

                        alert(a instanceof Array); //true

                        alert(a instanceof RegExp); //false

问题:

1.数据类型怎么转换?

答:请点击

2.引用类型的值是可变的吗?怎么改变?

答:引用类型的值是可变的

       怎么改变

3. Null 和 undefined有什么区别?

    两者是==的吗?为什么

答:null表示"没有对象",即该处不应该有值。典型用法是:

(1) 作为函数的参数,表示该函数的参数不是对象。

(2) 作为对象原型链的终点。

Object.getPrototypeOf(Object.prototype)// null

undefined表示"缺少值",就是此处应该有一个值,但是还没有定义。典型用法是:

(1)变量被声明了,但没有赋值时,就等于undefined。

(2) 调用函数时,应该提供的参数没有提供,该参数等于undefined。

(3)对象没有赋值的属性,该属性的值为undefined。

(4)函数没有返回值时,默认返回undefined。

null==undefined(因为转换),但是两者不全等

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,772评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,458评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,610评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,640评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,657评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,590评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,962评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,631评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,870评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,611评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,704评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,386评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,969评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,944评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,179评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,742评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,440评论 2 342

推荐阅读更多精彩内容