JavaScript 原始包装类型汇总

 更新时间:2022年05月26日 08:27:44   作者:​ 大力yy   ​  
这篇文章主要介绍了JavaScript 原始包装类型汇总,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下

前言:

引出问题: 如下一段简单的代码,变量a赋予了字符串类型原始值"str",通过控制台打印输出变量a,只有“str"。a并没有定义slice这个方法,但是后续为什么变量a可以调用slice方法呢?

let a = "str";
console.log(a);  // "str"
console.log(a.slice(1))  // "tr"

针对以上问题,需要追溯到JavaScript中的原始包装类型。

一、原始包装类型

为了方便操作原始值,ECMAScript提供了3种特殊的引用类型:Boolean、Number 和 String

关于Boolean、Number 和 String涉及的方法和属性很多,这里仅介绍三种引用类型的 valueOf() 方法和 toString() 方法。

1、Boolean

创建一个Boolean类型的对象实例时,传入的参数按转换为Boolean类型值的规则确实是true还是false

(1)valueOf() :返回一个原始值 true 或者 false

let a = new Boolean(true);
console.log(a.valueOf());  // true

(2)toString() :返回字符串 ‘true' 或者 'false'

let b = new Boolean(false);
console.log(b.toString());  // "false"

2、Number

(1)valueOf() :返回对象的原始数值

let a = new Number(12);
console.log(a.valueOf());  // 12

(2)toString() :返回相应基数(进制数)的数值字符串

let b = new Number(123);
console.log(b.toString());  // "123"

3、String

valueOf() 、toString() 和 toLocalString() 都继承自 Object,均返回对象的原始字符串值

let a = new String('str');
console.log(a.valueOf());  // str
console.log(a.toString());  // str
console.log(a.toLocaleString());  // str

二、原始包装类型的特点

1、原始值为什么可以调用一些方法

let s = "str";
console.log(s.slice(1))  // "tr"

如上代码,第二行中访问a时,是以读模式访问的,也就是要从内存中读取变量保存的值。

在以读模式访问字符串值得任何时候,后台都会自动执行以下三步:

(1)根据字符串值创建一个 String 类型的实例
(2)调用实例上的特定方法
(3)销毁实例

即相当于执行了以下三行代码:

// 创建String实例
let s = new String("str");
// 调用特定方法
s.slice(1)
// 销毁实例
s = null

这种行为则让原始值拥有了对象的行为。

针对布尔值和数值,也会在后台执行相同的步骤。

2、引用类型和原始值包装类型的区别

引用类型和原始值包装类型的区别主要在于对象的生命周期

  • (1)通过new实例化引用类型后,得到的实例会在离开作用域时被销毁
  • (2)自动创建的原始值包装对象则只会存在于访问它的那行代码执行期间。(所以运行时并不能给原始值添加属性和方法)

3、原始包装类型构造函数 和 转型函数

以Number为例:

  • (1)如果直接调用 Number(),执行的是 Number()转型函数,强制数值类型转换
  • (2)如果通过new 调用 Number(),执行的是 Number() 构造函数,创建一个Number的实例
let a = Number(1);
console.log(typeof a);   // number
let b = new Number(1);
console.log(typeof b);   // object

一个简单的知识点,主要自己之前学习太仓促,这些基础知识点并没有学习牢固,此复盘整理一下。

相关文章

  • JavaScript实现仿新浪微博大厅和腾讯微博首页滚动特效源码

    JavaScript实现仿新浪微博大厅和腾讯微博首页滚动特效源码

    最近看到朋友用JavaScript实现仿新浪微博大厅和未登录腾讯微博首页滚动效果,朋友使用jquery实现的,在网上看到有用js制作的也比较好,于是把我的内容整理分享给大家,具体详解请看本文
    2015-09-09
  • JavaScript工具库MyTools详解

    JavaScript工具库MyTools详解

    这篇文章主要为大家详细介绍了JavaScript工具库MyTools的相关资料,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-01-01
  • js中数组常用方法总结(推荐)

    js中数组常用方法总结(推荐)

    这篇文章主要介绍了js中数组常用方法总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • 轻松实现JavaScript图片切换

    轻松实现JavaScript图片切换

    这篇文章主要帮助大家轻松实现JavaScript图片切换,内容很精简,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-01-01
  • JavaScript iframe 实现多窗口通信实例详解

    JavaScript iframe 实现多窗口通信实例详解

    这篇文章主要为大家介绍了JavaScript iframe 实现多窗口通信实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • 关于同时使用swiper和echarts遇到的问题及解决方法

    关于同时使用swiper和echarts遇到的问题及解决方法

    这篇文章主要介绍了关于同时使用swiper和echarts遇到的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04
  • js实现自定义右键菜单

    js实现自定义右键菜单

    这篇文章主要为大家详细介绍了js实现自定义右键菜单,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • JavaScript中几种时间格式之间的简单转换

    JavaScript中几种时间格式之间的简单转换

    近期在练习或写项目时经常会遇到时间格式的转换问题,今天我就来总结一下,这篇文章主要给大家介绍了关于JavaScript中几种时间格式之间的简单转换,需要的朋友可以参考下
    2024-01-01
  • 小程序短信验证码页面实现demo

    小程序短信验证码页面实现demo

    这篇文章主要为大家介绍了小程序短信验证码页实现demo,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • JavaScript实现图片无缝滚动效果

    JavaScript实现图片无缝滚动效果

    这篇文章主要为大家详细介绍了JavaScript实现图片无缝滚动效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07

最新评论