小编给大家分享一下如何实现JS中‘hello’与new String(‘hello’)引出的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
创新互联公司"三网合一"的企业建站思路。企业可建设拥有电脑版、微信版、手机版的企业网站。实现跨屏营销,产品发布一步更新,电脑网络+移动网络一网打尽,满足企业的营销需求!创新互联公司具备承接各种类型的成都做网站、网站制作项目的能力。经过10多年的努力的开拓,为不同行业的企事业单位提供了优质的服务,并获得了客户的一致好评。
定义一个字符串
在工作中我们大概有3种方法去定义一个字符串:
1. var str = 'hello';
2. var str1 = String('hello');
3. var str2 = new String('hello');
(下文直接会带 以上三个变量....)
这三种方法定义出来的 'hello',都有自己的属性 例如lengh,有自己的方法例如: indexOf(),在日常工作定义中也没有感觉到任何的不同。
那是否深入过,
1.这三种方式定义出来的'hello',是否是一样的呢?
2.为什么基本类型可以直接调用其对应的方法呢?
这三种方式定义出来的'hello',是否是一样的呢?
console.log(str === str1) //true console.log(str === str2) //false console.log(str1 === str2) //false
我们可以发现 最后一种方式定义的 与上面两种方式定义的 不相等。
???
首先我们知道一个东西 就是:
new 出来的一定是对象。
所以分别 打出三个的类型:
console.log(typeof str) //string console.log(typeof str1) // string console.log(typeof str2) //object
所以这也就是为什么不会严格相等的原因。
引出数据类型 与 堆栈之间的关系
尝试深入理解原因:
我们知道,String,Number,Boolean在JS中是基本类型,基本类型是存储在栈(stack)内存中的,数据大小确定,内存空间大小可以分配。
而引用类型是存储在堆(heap)内存中的,例如对象, 栈中存在的仅仅是一个堆的指针,这也就是我们日常遇到 a = {num:1}, b=a, b.num1 = 2, 那么a.num1 也为2 的原因。因为a,b同时指向同一个地址。
前两种方式定义出来的是在栈中并且值相等,而第三种方法定义出来的仅仅是栈中的一个指针。
所以这也是为什么 三种方式定义出来的不一样。
为什么基本类型可以直接调用其对应的方法呢?
尝试:
console.log(str.length) // 5 str.say = 'world' console.log(str.say) //undefined console.log(str1.lengh) // 5 str1.say = 'world' console.log(str1.say) //undefined console.log(str2.lengh) // 5 str2.say = 'world' console.log(str.say) //world
引出包装对象和原始资料类型
我们发现第一种第二种方式均可访问lengh属性,
但是为什么我们并不能自定义一个属性并进行访问?
数字、字符串、布尔三者,在JS中称为原始的(primitives)资料类型,而 new String(), new Number() 就是包装对象。
包装对象也是对象。
这也就是为什么 我们打印 三种类型分别为 : string(原始资料类型) , string(原始资料类型) , object(包装对象).
我们可以理解 new 出来的 str2 对象有 String 的一系列方法
console.log(str2.indexOf === String.prototype.indexOf) // true
那尝试一下 第一种第二种方法 是否有同样的true?
console.log(str.indexOf === String.prototype.indexOf) //true console.log(str1.indexOf === String.prototype.indexOf) //true
但是:
str instanceof String // false str1 instanceof String // false
str 又 不属于String 却拥有 String 的方法?????
因为:
这是JS中的设计。
这是JS中的设计。
这是JS中的设计。
原始资料类型的方法与属性是"借"来的
一个原始的资料类型值,并没有如对象会有属性或方法,
原始的资料类型在运算时用的属性与方法,是向包装对象"借来"的用的,
所以原始资料类型是可以向 new String() 或者 new Number() 借来所有的方法。但是自己本身却没有属性和方法。
所以这也就是为什么第一种第二种我们无法去自定义属性却可以使用对应类型的方法的原因
以上是“如何实现JS中‘hello’与new String(‘hello’)引出的问题”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!
当前名称:如何实现JS中‘hello’与newString(‘hello’)引出的问题
链接地址:http://scpingwu.com/article/ppojij.html