返回顶部
首页 > 资讯 > 精选 >JavaScript原始包装类型实例分析
  • 732
分享到

JavaScript原始包装类型实例分析

2023-06-30 16:06:47 732人浏览 薄情痞子
摘要

这篇文章主要讲解了“javascript原始包装类型实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript原始包装类型实例分析”吧!引出问题: 如下一段简单的代

这篇文章主要讲解了“javascript原始包装类型实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“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());  // strconsole.log(a.toString());  // strconsole.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);   // numberlet b = new Number(1);console.log(typeof b);   // object

感谢各位的阅读,以上就是“JavaScript原始包装类型实例分析”的内容了,经过本文的学习后,相信大家对JavaScript原始包装类型实例分析这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: JavaScript原始包装类型实例分析

本文链接: https://lsjlt.com/news/330169.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JavaScript原始包装类型实例分析
    这篇文章主要讲解了“JavaScript原始包装类型实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript原始包装类型实例分析”吧!引出问题: 如下一段简单的代...
    99+
    2023-06-30
  • JavaScript 原始包装类型汇总
    目录一、原始包装类型1、Boolean2、Number3、String二、原始包装类型的特点1、原始值为什么可以调用一些方法2、引用类型和原始值包装类型的区别3、原始包装类型构造函数...
    99+
    2024-04-02
  • JavaScript 引用类型之原始值包装类型String
    目录String 原始值包装类型String 原始值包装类型 操作方法1.字符串编码常规化函数 normalize()方法2.字符串拼接函数concat()3.字符串提取子...
    99+
    2024-04-02
  • JavaScript原始值与包装对象的示例分析
    这篇文章主要介绍JavaScript原始值与包装对象的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!JavaScript有什么特点1、js属于一种解释性脚本语言;2、在绝大多数浏览器的支持下,js可以在多种平...
    99+
    2023-06-15
  • JavaScript原型实例分析
    这篇文章主要讲解了“JavaScript原型实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript原型实例分析”吧!先看三个对象一、构造函数(对象):JS中声明函数的三种...
    99+
    2023-06-29
  • Java泛型与包装类实例分析
    今天小编给大家分享一下Java泛型与包装类实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、什么是泛型泛型的本质是为...
    99+
    2023-06-29
  • JavaScript原型及实例分析
    今天就跟大家聊聊有关JavaScript原型及实例分析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。构造函数 实例 原型三者的关系任何函数都有一个prototype属性,该属性是一个...
    99+
    2023-06-22
  • JavaScript中引用类型之基本包装类型的示例分析
    这篇文章主要介绍JavaScript中引用类型之基本包装类型的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体如下:为了操作基本类型值,ECDMAScript提供了3个特殊...
    99+
    2024-04-02
  • JavaScript原型与继承实例分析
    今天小编给大家分享一下JavaScript原型与继承实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。首先我们需要知道的...
    99+
    2023-06-27
  • JavaScript原型、原型链和constructor属性实例分析
    本文小编为大家详细介绍“JavaScript原型、原型链和constructor属性实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript原型、原型链和constructor属性实例分...
    99+
    2024-04-02
  • JavaScript的原型对象与原型链实例分析
    本篇内容介绍了“JavaScript的原型对象与原型链实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、prototype和__pr...
    99+
    2023-07-02
  • javascript有什么原始类型
    小编给大家分享一下javascript有什么原始类型,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! ...
    99+
    2024-04-02
  • javascript原始类型有哪些
    javascript中的原始类型有:1.number,数值对象;2.string,字符串对象;3.boolean,布尔对象;4.undefined,未定义类型;5.null,空类型;6.symbol,唯一标识符;javascript中的原始...
    99+
    2024-04-02
  • JavaScript数据类型使用实例分析
    这篇文章主要讲解了“JavaScript数据类型使用实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript数据类型使用实例分析”吧! ...
    99+
    2024-04-02
  • JavaScript闭包实例分析
    这篇文章主要讲解了“JavaScript闭包实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript闭包实例分析”吧!   JavaSc...
    99+
    2024-04-02
  • javascript中原型与原型链的示例分析
    这篇文章主要为大家展示了“javascript中原型与原型链的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“javascript中原型与原型链的示例分析...
    99+
    2024-04-02
  • JavaScript中的数据类型Number实例分析
    这篇“JavaScript中的数据类型Number实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“JavaScript...
    99+
    2023-06-30
  • JavaScript中从原型到原型链的示例分析
    这篇“JavaScript中从原型到原型链的示例分析”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“JavaScript中从原型到原型链的示例分析”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望...
    99+
    2023-06-14
  • JavaScript原型继承的示例分析
    这篇文章主要介绍JavaScript原型继承的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在传统的基于Class的语言如Java、C++中,继承的本质是扩展一个已有的Cla...
    99+
    2024-04-02
  • JavaScript中String类型的示例分析
    这篇文章将为大家详细讲解有关JavaScript中String类型的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。String字符串转义符:转义序列字符\b退格\...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作