首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JS对象到原始值的转换

JS对象到原始值转换的复杂性 主要由于某些对象类型存在不止一种原始值的表示 对象到原始值转换的三种基本算法 在解释三种算法前需要了解toString valueOf这两个方法 toString...返回对象的字符串表示 Array类的toString方法会将每个元素转换为字符串,再使用逗号作为分隔符拼接起来 Function类的toString方法将定义的函数转换为JS源代码的字符串 Date类型的...toString方法返回一个人类友好(且JS可解析)的日期和时间字符串 RegExp类定义的toString方法将RegExp对象转换为一个看起来像RegExp字面量的字符串 valueOf 把对象转换为代表对象原始值...否则,转换失败 TypeError 偏数值 (该算法返回原始值,只要可能就返回数值) 与偏字符串算法类似,先尝试valueOf再尝试toString 无偏好 (该算法不倾向于任何原始值类型,而是由类定义自己的转换规则...) 取决于被转换对象的类 如果是Date对象,则使用偏字符串算法 其他类型使用偏数值算法 JS内置类型除了Date类都实现了偏数值算法;Date类实现了偏字符串算法 对象转换为布尔值 所有对象都转换为

4.3K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    攀爬TS之路(一) 原始数据类型、任意值类型

    攀爬TS之路(一) 原始数据类型、任意值类型 前言 之前简单了解过TypeScript,但是没有系统、深入学习,现在就来系统学习一下。...如1+'1'不会报错 TS和JS都是弱类型 console.log(2 + '1') 在TS和JS中都不会报错,因为TS是完全兼容JS的,不会修改JS运行时的特性,所以它们都是弱类型。...原始数据类型 原始数据类型包括:number、string、boolean、null、undefined和Symbol、BigInt(ES6新增) 这个部分实际上,TS和JS差别不大,举个例子就能懂了。...,那么对它的操作,返回的结果的类型都是任意值,而且任意值也就意味着有可能会是对象,所以是没法在编译时暴露出错误的。...另外,除了上面声明时指定类型的情况,如果变量在声明时,没有指定它的类型,也没有被赋值,那么就会被识别成任意值类型。

    76230

    js中的值类型和引用类型的区别

    js中的值类型和引用类型的区别 1.JavaScript中的变量类型有哪些?...(1)值类型(基本类型):字符串(string)、数值(number)、布尔值(boolean)、undefined、null (这5种基本数据类型是按值访问的,因为可以操作保存在变量中的实际的值)(...几方面的区别举例: (1)动态的属性: 定义基本类型值和引用类型值的方式是类似的。但是,当这个值保存到变量中以后,对不同类型值可以执行的操作则大相径庭。...对于引用类型的值,我们可以为其添加属性和方法,也可以改变和删除其属性和方法,但是,我们不能给基本类型的值添加属性,只能给引用类型值动态地添加属性,以便将来使用。...但是,当接下来再访问 person.name 时,显示的值仍然是"Nicholas"。 这说明即使在函数内部修改了参数的值,但原始的引用仍然保持未变。

    3.5K20

    原生JS | 值类型与引用类型变量

    HTML5学堂-码匠:在JavaScript中,存在着两种不同的变量类型,一种是值类型变量,一种是引用类型变量。...其中数组、对象、函数都属于引用类型变量,数值、布尔值、null、undefined、字符串属于值类型变量,不同类型变量在参数传递方面有不同的运行机制。...:值类型和引用类型。...不同类型的数据在“赋值”时机制并不相同。 欢迎沟通交流~~~HTML5学堂(码匠) 值类型变量 值类型包括:数值、布尔值、null、undefined、字符串。...对于值类型变量,变量的交换(将一个变量赋值给另一个变量)相当于是创建了一个新的空间,把原有的变量值复制一份,并将其存储在新空间当中,新空间与之前空间互不影响。

    3.5K90

    JavaScript-原始值和引用值

    一、原始值和引用值的概念 在 ECMAScript 中,变量可以存在两种类型的值,即原始值和引用值。...1.1 原始值 (1)原始值指的是 原始类型 的值,也叫 基本类型,例如 Number、Stirng、Boolean、Null、Underfined 。...二、栈和堆 2.1 原始值存储在栈中 为变量赋值时,ECMAScript 的解释程序必须判断该值是原始类型,还是引用类型。...由于这些原始类型占据的空间是固定的,所以可将他们存储在较小的内存区域 - 栈中。这样存储便于迅速查寻变量的值。 2.2 引用值存储在堆中 如果一个值是引用类型的,那么它的存储空间将从堆中分配。...五、比较方式不同 5.1 原始值的比较是 值 的比较 5.2 引用值的比较是 引用 的比较 5.3 Example ? 5.4 说明 (1)原始值 a 和 b 的数据类型不同,但也可以进行值的比较。

    1K51

    4.1 红宝书 📒 原始值与引用值

    原始值与引用值 原始值:最简单的数据 (Undefined、Null、Boolean、Number、String、Symbol)。我们操作的就是存储在变量的实际值 引用值:多个值构成的对象。...是保存在内存中的对象。Js不允许直接访问内存位置,不能直接操作对象所在的内存空间。实际操作的是对该对象的引用。 动态属性 原始值和引用值的定义 都是创建一个变量,然后给它赋值。...,如果使用new关键字,则javaScript创建一个Object类型的实例,但其行为类似原始值 let obj = new String("font") obj.name = "objName" console.log...,但是上面这个引用值的例子,在函数内部给obj添加name属性,函数外部对象也会反映这个变化,就感觉引用类型的参数是按引用值传递的。...ECMAScript中函数的参数就是局部变量 确定类型 typeof适用于原始类型,对于引用值只能判断出是object类型。但是我们通常要知道是什么样的对象。

    38410

    复杂值vs原始值&&内存空间

    那么我们先来聊一下JavaScript的原始值(值类型)以及复杂值(引用类型),以及他们在内存空间中的存储,关于他们你可能不清楚的一些事:      我们先通过一个经典的面试题类型(并不是原题,我即兴发挥...事实上,原始值存储在栈内存中,按值来访问。复杂值(引用类型)在堆内存里面,按引用地址访问;然后我们会想到局部变量和全局变量在内存中的存储:下面是我在一个群中给一个同行的回答(前辈们莫见笑) ?...1、原始值是非对象 我们老生常谈的JavaScript五大基本的数据类型,null、undefined、number、string、boolean都被视为原始值,因为他们是不可细化的,本身是简单的,不能表示由其他的值组成的值...这里的重点是,原始值是作为不可细化的值进行存储和操作的,引用他们会转移其值:这里的意思也就是原始值(值类型)在内存中每一个值都会存储在对应的变量的中去,也就是一个真实值的”复制”。   ...写在后面 相信到这里我们对js中的原始值、复杂值、以及他们的特性、在内存中的存储有了比较深入的理解,那么让我们开始准确我们的JavaScript世界观系列,因为我从高中毕业后接触前端,对原生的热爱程度远远大于

    86370

    JavaScript 原始值与包装对象

    ---- 正文 原始类型 (Primitive types) 原始类型也被称为“基本类型”。...在 JavaScript 最初的实现中,JavaScript 中的值是由一个表示类型的标签和实际数据值表示的。对象的类型标签是 0。...The history of “typeof null”:https://2ality.com/2013/10/typeof-null.html 原始值 (Primitive values) 原始值也就是原始类型的值...原始值是一种没有任何方法的非对象数据。 也就是说,string、number 和 boolean 等原始类型的值本身是没有任何属性和方法的。...最后我们来总结一下: 多数原始类型都有相应的包装对象; 有些包装对象可以被 new,有些不行; 包装对象一般被用来进行显式的类型转换; 对象上有属性和方法; 原始值上没有属性和方法; 原始值上也不能有属性和方法

    90310

    JavaScript 原始值与包装对象

    --- 正文 原始类型 (Primitive types) 原始类型也被称为“基本类型”。...在 JavaScript 最初的实现中,JavaScript 中的值是由一个表示类型的标签和实际数据值表示的。对象的类型标签是 0。...The history of “typeof null”:https://2ality.com/2013/10/typeof-null.html 原始值 (Primitive values) 原始值也就是原始类型的值...原始值是一种没有任何方法的非对象数据。 也就是说,string、number 和 boolean 等原始类型的值本身是没有任何属性和方法的。...最后我们来总结一下: 多数原始类型都有相应的包装对象; 有些包装对象可以被 new,有些不行; 包装对象一般被用来进行显式的类型转换; 对象上有属性和方法; 原始值上没有属性和方法; 原始值上也不能有属性和方法

    94540

    TypeScript 原始数据类型

    简而言之,类型声明给变量设置了类型,使得变量只能存储某种类型的值 Snipaste_2021-05-18_14-09-22.jpg TypeScript 中的数据类型分为两大类 原始数据类型(基本数据类型...任意类型 unknown * 类型安全的any void 空值(undefined) 没有值(或undefined) never 没有值 不能是任何值 object (name: '罗') 任意的 js...对象 array 1, 2, 3 任意的 js 数组 tuple 4, 5 元组,TS 新增类型,固定长度的数组 enum enum(A, B) 枚举,TS 中新增类型 在 ES6 和 ES10 中引入了新的基本数据类型...,分别是 Symbol 和 BigInt 原始数据类型 数字类型 使用关键字number定义数字类型 let decimal: number = 6.1; // 小数 let hex: number...; // 声明但未赋值的变量值(找不到值) Null类型 表示对象缺失 let nu: null = null; // 声明并已赋值(能找到,值就是null) Undefined类型 用于初始化变量为一个未定义的值

    82350

    Solidity:原始数据类型

    在Solidity中,有几种原始的数据类型,以下是每种类型和它们的一般用途: 1.bool:布尔类型,可以是true或false。它常常在逻辑判断中使用。...这种类型常常用来处理二进制数据。5.bytes:动态长度的字节序列。这种类型常常用来处理任意长度的二进制数据。6.string:动态长度的字符串。这种类型常常用来处理任意长度的字符串数据。...7.mapping:这是一种键-值对存储类型,可以存储几乎任意类型的数据。8.fixed / ufixed:固定点数类型。可以声明定长浮点型的变量,但不能给它们赋值或把它们赋值给其他变量。...但是目前(2024年5月),这种类型还处于实验阶段,没有正式发布。 每种类型都有特定的用途,并且在智能合约中扮演了重要的角色。...在编写智能合约时,选择合适的数据类型可以优化性能,降低gas消耗,并增强代码的可读性和可维护性。

    19510

    TypeScript 中的基础类型:原始类型、对象类型、数组类型、元组类型、枚举类型和联合类型

    TypeScript 强大的类型系统使得开发者能够更轻松地编写可维护、可扩展的代码。本文将详细介绍 TypeScript 中的基础类型,包括原始类型、对象类型、数组类型、元组类型、枚举类型和联合类型。...原始类型在 TypeScript 中,有以下几种原始类型:数字类型数字类型用于表示整数或浮点数。可以使用 number 关键字来声明数字变量。...例如:let isTrue: boolean = true;空值和未定义类型空值类型 (void) 用于表示没有返回值的函数。未定义类型 (undefined) 用于表示未赋值的变量。...例如:let nothing: null = null; // 空值类型let nul: null = null; // 空值类型对象类型对象类型用于表示非原始数据类型,包括对象、数组、函数等。...总结本文详细介绍了 TypeScript 的基础类型,包括原始类型、对象类型、数组类型、元组类型、枚举类型和联合类型等方面。

    78130

    JS获取图片原始宽高

    最近在给博客的相册模块做优化,需要知道图片的原始大小,我以前的做法是把图片的真实宽高分别放在data-width和data-height中,效果是达到了,但是总觉得扩展性很低,当不知道图片的大小时,还要一张一张图片的去查看图片信息手动输入图片大小...,很繁琐 获取图片大小: 1.使用innerWidth,innerHeight 使用HTMLImageElement.innerWidth 是可以拿到图片的宽度 但是需要注意的是这里拿到的宽度是图像在CSS...像素中渲染的宽度 也就是说如果图片原始大小1200,使用css或者width属性设置为600,那么这里拿到的宽度为600,显然用innerWidth获取图片原始尺寸是不靠谱的 2.使用document.createElement...需要注意的是在给img的src赋值时,这是一个异步过程,会存在获取img的宽度时值为0(图片还未加载完成),可以在给img赋值之前加上onload事件 var img = document.createElement....jpg" 3.使用naturalWidth(推荐) 使用HTMLImageElement.naturalWidth拿到图像在CSS像素中固有的宽度,如果可用的话; 否则, 返回0 这样就可以拿到图片的原始大小

    6.4K20

    深入理解面向对象中的原始类型和引用类型

    引用类型 引用类型的数据指的是JS中的对象,类似于其他编程语言中的类。对象是由一系列的键值对(属性名和属性值)组成的无序列表。...原始包装器类型也是引用类型,当字符串,数字或布尔值被读取的时候,原始包装器类型会自动在后台创建。...总结 JavaScript没有类,但是它有类型,分为原始类型和引用类型。 原始类型的值直接被保存在变量中,引用类型的值并不是直接保存变量中,变量中保存的仅仅是引用类型的值所在的内存地址。...在检测原始类型的值时,除了null以外,其他的原始类型都可以使用typeof操作符。null必须跟特殊值null进行比较(value === null)。...为了使我们在操作原始类型数据的时候更加方便,JavaScript允许原始类型的值使用方法。

    1.4K30
    领券