JavaScript各种基础对象:(2)包装对象

2024-06-22 17:58
文章标签 java 基础 script 对象 包装

本文主要是介绍JavaScript各种基础对象:(2)包装对象,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1 包装对象

1.1 定义

1.2 包装对象的构造函数

1.3 包装对象实例的方法

1.3.1 valueOf方法

1.3.2 toString方法

1.4 原始类型的自动转换

1.5 自定义方法


1 包装对象

1.1 定义

在JavaScript中,“一切皆对象”,数组和函数本质上都是对象,就连三种原始类型的值——数值、字符串、布尔值——在一定条件下,也会自动转为对象,也就是原始类型的“包装对象”。

所谓“包装对象”,就是分别与数值、字符串、布尔值相对应的Number、String、Boolean三个原生对象。这三个原生对象可以把原始类型的值变成(包装成)对象。

var v1 = new Number(123);
var v2 = new String("abc");
var v3 = new Boolean(true);

上面代码根据原始类型的值,生成了三个对象,与原始值的类型不同。这用typeof运算符就可以看出来。

typeof v1 // "object"
typeof v2 // "object"
typeof v3 // "object"v1 === 123 // false
v2 === "abc" // false
v3 === true // false

JavaScript设计包装对象的最大目的,首先是使得JavaScript的“对象”涵盖所有的值。其次,使得原始类型的值可以方便地调用特定方法。

1.2 包装对象的构造函数

Number、String和Boolean这三个原生对象,既可以当作构造函数使用(即加上new关键字,生成包装对象实例),也可以当作工具方法使用(即不加new关键字,直接调用),这相当于生成实例后再调用valueOf方法,常常用于将任意类型的值转为某种原始类型的值。

Number(123) // 123String("abc") // "abc"Boolean(true) // true

工具方法的详细介绍参见第二章的《数据类型转换》一节。

1.3 包装对象实例的方法

包装对象实例可以使用Object对象提供的原生方法,主要是 valueOf 方法和 toString 方法。

1.3.1 valueOf方法

valueOf方法返回包装对象实例对应的原始类型的值

new Number(123).valueOf()
// 123new String("abc").valueOf()
// "abc"new Boolean("true").valueOf()
// true

1.3.2 toString方法

toString方法返回该实例对应的原始类型值的字符串形式。

new Number(123).toString()
// "123"new String("abc").toString()
// "abc"new Boolean("true").toString()
// "true"

1.4 原始类型的自动转换

原始类型可以自动调用定义在包装对象上的方法和属性。比如String对象的实例有一个length属性,返回字符串的长度。

var v = new String("abc");
v.length // 3

所有原始类型的字符串,都可以直接使用这个length属性。

"abc".length // 3

上面代码对字符串abc调用length属性,实际上是将“字符串”自动转为String对象的实例,再在其上调用length属性。这就叫原始类型的自动转换。

abc是一个字符串,属于原始类型,本身不能调用任何方法和属性。但当对abc调用length属性时,JavaScript引擎自动将abc转化为一个包装对象实例,然后再对这个实例调用length属性,在得到返回值后,再自动销毁这个临时生成的包装对象实例。

这种原始类型值可以直接调用的方法还有很多,除了前面介绍过的valueOf和stringOf方法,还包括三个包装对象各自定义在实例上的方法。

'abc'.charAt === String.prototype.charAt
// true

上面代码表示,字符串abc的charAt方法,实际上就是定义在String对象实例上的方法(关于prototype对象的介绍参见《面向对象编程》一章)。

如果包装对象与原始类型值进行混合运算,包装对象会转化为原始类型(实际是调用自身的valueOf方法)。

new Number(123) + 123
// 246new String("abc") + "abc"
// "abcabc"

1.5 自定义方法

三种包装对象还可以在原型上添加自定义方法和属性,供原始类型的值直接调用。

比如,我们可以新增一个double方法,使得字符串和数字翻倍。

String.prototype.double = function (){return this.valueOf() + this.valueOf();
};"abc".double()
// abcabcNumber.prototype.double = function (){return this.valueOf() + this.valueOf();
};(123).double()
// 246

上面代码在123外面必须要加上圆括号,否则后面的点运算符(.)会被解释成小数点。

但是,这种自定义方法和属性的机制,只能定义在包装对象的原型上,如果直接对原始类型的变量添加属性,则无效。

var s = "abc";s.p = 123;
s.p // undefined

上面代码直接对支付串abc添加属性,结果无效。

这篇关于JavaScript各种基础对象:(2)包装对象的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1085001

相关文章

Java方法重载与重写之同名方法的双面魔法(最新整理)

《Java方法重载与重写之同名方法的双面魔法(最新整理)》文章介绍了Java中的方法重载Overloading和方法重写Overriding的区别联系,方法重载是指在同一个类中,允许存在多个方法名相同... 目录Java方法重载与重写:同名方法的双面魔法方法重载(Overloading):同门师兄弟的不同绝

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

Java中ArrayList与顺序表示例详解

《Java中ArrayList与顺序表示例详解》顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构,:本文主要介绍Java中ArrayList与... 目录前言一、Java集合框架核心接口与分类ArrayList二、顺序表数据结构中的顺序表三、常用代码手动

JAVA项目swing转javafx语法规则以及示例代码

《JAVA项目swing转javafx语法规则以及示例代码》:本文主要介绍JAVA项目swing转javafx语法规则以及示例代码的相关资料,文中详细讲解了主类继承、窗口创建、布局管理、控件替换、... 目录最常用的“一行换一行”速查表(直接全局替换)实际转换示例(JFramejs → JavaFX)迁移建

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

JAVA线程的周期及调度机制详解

《JAVA线程的周期及调度机制详解》Java线程的生命周期包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED,线程调度依赖操作系统,采用抢占... 目录Java线程的生命周期线程状态转换示例代码JAVA线程调度机制优先级设置示例注意事项JAVA线程

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位

springboot的controller中如何获取applicatim.yml的配置值

《springboot的controller中如何获取applicatim.yml的配置值》本文介绍了在SpringBoot的Controller中获取application.yml配置值的四种方式,... 目录1. 使用@Value注解(最常用)application.yml 配置Controller 中