返回顶部
首页 > 资讯 > 前端开发 > html >javascript拆箱装箱和类型转换的方法
  • 892
分享到

javascript拆箱装箱和类型转换的方法

2024-04-02 19:04:59 892人浏览 安东尼
摘要

这篇“javascript拆箱装箱和类型转换的方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看

这篇“javascript拆箱装箱和类型转换的方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“javascript拆箱装箱和类型转换的方法”文章吧。

javascript拆箱装箱和类型转换的方法

基本数据类型:stringnumberboolean

引用类型:objectfunction

不存在的类型:undefined

StringNumberBoolean分别属于stringnumberboolean三个原始类型的包装类型,它们的对象属于引用类型。

装箱

装箱是指把基本数据类型转换为对应的引用类型的操作,该过程主要是指stringnumberboolean类型的数据,通过StringNumberBoolean进行包装成为引用类型数据的过程。

// 隐式装箱var s1 = 'Hello World'; 
var s2 = s1.substring(2);

上面第二行代码的执行步骤其实是这样的:

  1. 使用new String('Hello World')创建一个临时的实例对象;

  2. 使用临时对象调用substring方法;

  3. 将执行结果赋值给s2;销毁临时的实例对象。

上面的步骤转换为代码,如下:

// 显式装箱var s1 = 'Hello World'; 
var tempObj = new String('Hello World');
var s2 = tempObj.substring(2);

拆箱

拆箱是把引用类型转换为基本的数据类型。

关于拆箱过程中的ToPrimitive

类型转换

运算符对于两端的变量,都有一个期待类型,在javascript中,凡是不满足运算符期待类型的变量,都会做做隐式转换。

逻辑运算符

在进行逻辑运算时,隐式转换只有一个标准:只有 nullundefined''NaN0false 表示 false,其他的情况都是 true,比如 {} , []

算术运算符
  1. 如果算术运算符两端均为number类型的数据,直接进行计算;

  2. 如果算术运算符两端存在非number的基本数据类型,则对非number的运算数使用Number()进行装箱,然后对返回值进行拆箱为number类型,参与计算;

  3. 算术运算符两端存在引用数据类型,则先对引用类型进行拆箱操作,如果结果为非number类型,则根据条件2执行,否则执行条件1

1 - true 
// 0, 首先 Number(true) 转换为数字 1, 然后执行 1 - 11 - null 
// 1,  首先把 Number(null) 转换为数字 0, 然后执行 1 - 01 * undefined 
//  NaN, Number(undefined) 转换为数字是 NaN , 然后执行 1 * NaN2 * ['5'] 
//  10, ['5'] 依照ToPrimitive规则进行拆箱会变成 '5', 然后通过 Number('5') 进行拆装箱再变成数字 5123 + {valueOf:()=>{return 10}}   
// 133  {valueOf:()=>{return 10}} 依照ToPrimitive规则会先调用valueOf,获得结果为10

+作为单目运算符出现在变量的前面时,表示的意思是将变量转换为Number类型

+"10" 	
// 10  同 Number("10")+['5']  
// 5   ['5']依照ToPrimitive规则会变成 '5', 然后通过`Number`的拆箱操作再变成数字 5
字符串连接符

字符串连接符的符号同算术运算符的+

  1. 如果算术运算符两端均为string类型的数据,直接进行连接

  2. 如果运算符的两端存在非string的基本类型,则对非string的基本类型数据使用String()进行装箱,然后对返回值进行拆箱为基本类型,参与字符串拼接。

  3. +两端两端存在引用数据类型,则先对引用类型进行拆箱操作,如果结果为非string类型,则根据条件2执行,否则执行条件1

关系运算符
  • NaN和其他任何类型,做任何关系运算永远返回false(包括和他自己)。如果想判断一个变量是不是NaN , 可以通过Number.isNaN()来判断。

  • null == undefined比较结果是true,除此之外,nullundefined和其他的(不包括它们自身)任何结果的比较值都为false

    这里是规则定义的,null 为 object 的类型,可是调用valueOf或者toString都会有语法错误,这里直接记住结果就行。

  • 一般情况:

    1. 如果算术运算符两端均为number类型的数据,直接进行计算;

    2. 如果算术运算符两端存在非number的基本数据类型,则对非number的运算数使用Number()进行装箱,然后对返回值进行拆箱为number类型,参与计算;

    3. 算术运算符两端存在引用数据类型,则先对引用类型进行拆箱操作,如果结果为非number类型,则根据条件2执行,否则执行条件1

{} == !{}  
// false   Number({}.valueOf().toString())==> NaN , 所以题目等同于 NaN == false , NaN 和 任何类型比较都是 false[] == []  
// false  内存地址不同![] == 0  
// true   ![]==>false , 所以题目等同于 false==0 , Number(false)==>0 ,  所以结果为 true

一些题目

  1. [] == ![]

        - 第一步,![] 会变成 false
        - 第二步,[]的valueOf是[],[]是引用类型,继续调用toString,题目变成: "" == false
        - 第三步,符号两端转换为Number, 得到 0==0
        - 所以, 答案是 true
  2. [undefined] == false

        - 第一步,[undefined]的valueOf结果为 [undefined],然后[undefined]通过toString变成 '' ,所以题目变成  '' == false
        - 第二步,符号两端转换为Number, 得到 0==0
        - 所以, 答案是 true !
  3. 如何使a==1 && a==2 && a==3的结果为 true

    var a = {
        value: 0,
        valueOf: function() {
            this.value += 1;
            return this.value    }};console.log(a == 1 && a == 2 && a == 3) // true
  4. 如何使a===1&&a===2&&a===3的结果为 true

    // 使用 defineProperty 进行数据劫持var value = 0;Object.defineProperty(window,"a",{
        get(){
            return ++value;
        }})console.log(a===1&&a===2&&a===3)  //true
  5. 实现一个无限累加函数

  6. 柯里化实现多参累加

以上就是关于“javascript拆箱装箱和类型转换的方法”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网html频道。

--结束END--

本文标题: javascript拆箱装箱和类型转换的方法

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

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

猜你喜欢
  • javascript拆箱装箱和类型转换的方法
    这篇“javascript拆箱装箱和类型转换的方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看...
    99+
    2024-04-02
  • C#装箱和拆箱的原理介绍
    我们知道,值类型的变量是在堆栈上分配内存的,而引用类型包括System.Object的对象是在堆上分配内存的,基于这一特点,当值类型被类型转换时,会在堆栈和堆上进行一系列的操作,这就...
    99+
    2024-04-02
  • Java中的装箱和拆箱是什么
    本篇内容介绍了“Java中的装箱和拆箱是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!目录装箱拆箱==null总结装箱八大基本类型都有一...
    99+
    2023-06-20
  • Java基础详解之包装类的装箱拆箱
    目录一、包装类二、装箱与拆箱三、静态方法四、自动装箱与自动拆箱一、包装类 概念: Java提供了两个类型系统,基本数据类型和引用数据类型,使用基本数据类型在于效率,然而很多情况下回创...
    99+
    2024-04-02
  • Java的自动装箱和拆箱的概念
    本篇内容主要讲解“Java的自动装箱和拆箱的概念”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java的自动装箱和拆箱的概念”吧!Java作为面向对象语言,有人认为所看到的都是对象,事实上,在J...
    99+
    2023-06-17
  • C#中的装箱和拆箱简单描述
    本篇内容主要讲解“C#中的装箱和拆箱简单描述”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#中的装箱和拆箱简单描述”吧!C#装箱和拆箱还是别名许多 C#.NET 的书上都有介绍 int -&g...
    99+
    2023-06-17
  • java装箱和拆箱的概念是什么
    Java装箱和拆箱是将基本数据类型转换为对应的包装类类型(装箱)和将包装类类型转换为对应的基本数据类型(拆箱)的过程。装箱(Boxi...
    99+
    2023-10-07
    java
  • C#里的装箱和拆箱是什么意思
    这篇文章主要讲解了“C#里的装箱和拆箱是什么意思”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#里的装箱和拆箱是什么意思”吧!C#装箱和拆箱机制使得在C#类型系统中,任何值类型,引用类型和...
    99+
    2023-06-17
  • Java的自动装箱和拆箱源码分析
    这篇“Java的自动装箱和拆箱源码分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java的自动装箱和拆箱源码分析”文章吧...
    99+
    2023-06-30
  • 一文探寻Java装箱和拆箱的奥妙
    目录前言什么是装箱和拆箱装箱拆箱为啥要包装类型装箱和拆箱的进化过程到底该如何选择呢总结前言 今天在逛某知名论坛的时候,看到一篇"请不要使用包装类型,避免造成性能损失&quo...
    99+
    2023-05-18
    Java装箱 拆箱选择 Java装箱 拆箱 Java装箱 Java 拆箱
  • JavaScript类型转换的方法
    这篇文章主要讲解了“JavaScript类型转换的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript类型转换的方法”吧!  ...
    99+
    2024-04-02
  • java自动装箱和自动拆箱的定义是什么
    自动装箱(Autoboxing)指的是Java编程语言中的一种特性,它允许将基本数据类型自动转换为对应的包装类类型。例如,当我们将一...
    99+
    2023-10-27
    java
  • 详谈java中int和Integer的区别及自动装箱和自动拆箱
    目录int和Integer的区别及自动装箱和自动拆箱Integer和int的对比,如下所示:自动装箱和自动拆箱:Integer的自动拆装箱的陷阱(整型数-128到127的值比较问题)...
    99+
    2024-04-02
  • JavaScript各种类型的转换方法
    这篇文章主要讲解了“JavaScript各种类型的转换方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript各种类型的转换方法”吧!Java...
    99+
    2024-04-02
  • JavaScript类型转换的方法有哪些
    今天小编给大家分享一下JavaScript类型转换的方法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们...
    99+
    2024-04-02
  • javascript进行强制类型转换的方法
    这篇文章给大家分享的是有关javascript进行强制类型转换的方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。强制转换方法:1、使用ToString()、ToNumber()或ToBoolean()方法;2、...
    99+
    2023-06-14
  • javascript进行类型强制转换的方法
    小编给大家分享一下javascript进行类型强制转换的方法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!强制转换方法:1、使用String()、Number()或toString()函数进行字符串与数字之间的显示类型转换...
    99+
    2023-06-15
  • .NET避免装箱的方法
    .NET提供struct类型,正确使用可以减少对象数量,从而降低GC压力,提高性能。不过有时候我会发现,某些同学有这方面的意识,但是有时候一疏忽一偷懒,就没有得到相应的效果了。这里举...
    99+
    2024-04-02
  • JavaScript强制类型转换方法有哪些
    这篇文章主要介绍“JavaScript强制类型转换方法有哪些”,在日常操作中,相信很多人在JavaScript强制类型转换方法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解...
    99+
    2024-04-02
  • go 类型转换方式(interface 类型的转换)
    go 在做类型转换时,报错: cannot convert m (type interface {}) to type Msg: need type assertion 原...
    99+
    2022-06-07
    GO interface 类型转换
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作