JS中‘hello’与new String(‘hello’)引出的问题详解


Posted in Javascript onAugust 14, 2018

定义一个字符串

在工作中我们大概有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() 借来所有的方法。但是自己本身却没有属性和方法。

所以这也就是为什么第一种第二种我们无法去自定义属性却可以使用对应类型的方法的原因

总结:

1.第一种和第二种方法定义出来的是原始资料类型

并储存于栈中,

并向包装对象(new ..())借来方法和属性.

2.第三种是 包装对象,

栈中储存堆指针,

堆中储存内容。

所以这也是发生一系列看似不正常但是又正常的事情的原因,

哈哈哈哈哈哈哈哈。

当然还有很多的东西,既然牵扯到了堆栈,

那么又不得不了解一下堆栈到底是什么,

有什么区别等等。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
33种Javascript 表格排序控件收集
Dec 03 Javascript
用Mootools获得操作索引的两种方法分享
Dec 12 Javascript
JavaScript 对任意元素,自定义右键菜单的实现方法
May 08 Javascript
javascript打印html内容功能的方法示例
Nov 28 Javascript
使用jquery中height()方法获取各种高度大全
Apr 02 Javascript
JavaScript 监控微信浏览器且自带返回按钮时间
Nov 27 Javascript
vue-infinite-loading2.0 中文文档详解
Apr 08 Javascript
JavaScript函数式编程(Functional Programming)组合函数(Composition)用法分析
May 22 Javascript
Vue2.0实现简单分页及跳转效果
Jul 29 Javascript
JavaScript基础之this和箭头函数详析
Sep 05 Javascript
使用Element的InfiniteScroll 无限滚动组件报错的解决
Jul 27 Javascript
VUE-ElementUI 自定义Loading图操作
Nov 11 Javascript
Vue.js单向绑定和双向绑定实例分析
Aug 14 #Javascript
微信小程序异步API为Promise简化异步编程的操作方法
Aug 14 #Javascript
jQuery实现的简单拖拽功能示例【测试可用】
Aug 14 #jQuery
jQuery+CSS实现的标签页效果示例【测试可用】
Aug 14 #jQuery
layui的table单击行勾选checkbox功能方法
Aug 14 #Javascript
解决layui 复选框等内置控件不显示的问题
Aug 14 #Javascript
深入浅析Node环境和浏览器的区别
Aug 14 #Javascript
You might like
全文搜索和替换
2006/10/09 PHP
中国站长站 For Dede4.0 采集规则
2007/05/27 PHP
ThinkPHP表单自动验证实例
2014/10/13 PHP
PHP使用GD库输出汉字的方法【测试可用】
2016/11/10 PHP
用php+ajax新建流程(请假、进货、出货等)
2017/06/11 PHP
jquery tools 系列 scrollable(2)
2009/09/06 Javascript
纯js实现背景图片切换效果代码
2010/11/14 Javascript
JS中使用Array函数shift和pop创建可忽略参数的例子
2014/05/28 Javascript
jQuery源码分析之jQuery中的循环技巧详解
2014/09/06 Javascript
ANGULARJS中用NG-BIND指令实现单向绑定的例子
2014/12/08 Javascript
JavaScript中对象介绍
2014/12/31 Javascript
介绍JavaScript的一个微型模版
2015/06/24 Javascript
常用的Javascript设计模式小结
2015/12/09 Javascript
50 个 jQuery 插件可将你的网站带到另外一个高度
2016/04/26 Javascript
jQuery实现拖动效果的实例代码
2017/06/25 jQuery
Vue父子模版传值及组件传值的三种方法
2017/11/27 Javascript
利用jQuery+localStorage实现一个简易的计时器示例代码
2017/12/25 jQuery
vue中Axios的封装与API接口的管理详解
2018/08/09 Javascript
解决vue的 v-for 循环中图片加载路径问题
2018/09/03 Javascript
ant-design-vue 时间选择器赋值默认时间的操作
2020/10/27 Javascript
[53:15]2018DOTA2亚洲邀请赛3月29日 小组赛A组 KG VS OG
2018/03/30 DOTA
Python生成器(Generator)详解
2015/04/13 Python
python爬虫实战之爬取京东商城实例教程
2017/04/24 Python
Python从零开始创建区块链
2018/03/06 Python
python如何实现异步调用函数执行
2019/07/08 Python
django2.2 和 PyMySQL版本兼容问题
2020/02/17 Python
keras 回调函数Callbacks 断点ModelCheckpoint教程
2020/06/18 Python
美国最好的保健品打折网店:Swanson
2017/08/04 全球购物
Notino匈牙利:购买香水和化妆品
2019/04/12 全球购物
艺术系应届生的自我评价
2013/10/19 职场文书
4s店总经理岗位职责
2013/12/31 职场文书
医院院务公开实施方案
2014/05/03 职场文书
感恩的演讲稿
2014/05/06 职场文书
党的群众路线教育实践活动个人剖析材料
2014/10/07 职场文书
Python基于百度AI实现抓取表情包
2021/06/27 Python
vue中this.$http.post()跨域和请求参数丢失的解决
2022/04/08 Vue.js