JavaScript 中的toString()方法,我们通常会一些其他类型的变量,转为字符串类型。但这里还有一些其他奇妙的用法。

不同的类型调用 toString() 会得到不同的结果。我们来一一分析下。

1. 函数类型

我们开发者自定义的函数,和 JavaScript 官方内置的函数,在调用 toString 时,输出是不一样的。

function user() {
const name = "蚊子";
}
user.toString(); // 'function user() {const name = "蚊子";}'
Math.abs.toString(); // 'function abs() { [native code] }'

自定义函数在调用toString()时,输出的是函数体的内容。而内置函数,则输出的是native code

2. Boolean 类型

boolean 类型的最简单,就是把 true 和 false 转为对应的字符串。

const yes = true;
const no = false; yes.toString(); // 'true'
no.toString(); // 'false'

3. 数字类型

可以把数字转为对应进制的字符串toString(radix),传入的参数为要转换的进制,范围是2~36之间,若不传参,则默认转为 10 进制的字符串。

const count = 10;

console.log(count.toString()); // 输出 '10'
console.log((17).toString()); // 输出 '17'
console.log((17.2).toString()); // 输出 '17.2' const x = 6; console.log(x.toString(2)); // 转为2进制,输出 '110'
console.log((254).toString(16)); // 转为16进制,输出 'fe' console.log((-10).toString(2)); // 转为2进制,输出 '-1010'
console.log((-0xff).toString(2)); // 16进制转为2进制,输出 '-11111111'

还有一个常用的方法parseInt(stirng, radix),把当前字符串以 radix 指定的进制,转为 10 进制的数字。

parseInt("14", 8); // 8进制的14转为10进制,输出12
parseInt("a", 16); // 16进制的a转为10进制,输出10
parseInt("1011", 2); // 2进制的1011转为10进制,输出11

我们把 parseInt()toString()进行结合,可以在2~36进制之间任意转换。

const transform = (base, from, to) => {
if (from < 2 || from > 36 || to < 2 || to > 36) {
throw new RangeError("transform radix argument must be between 2 and 36");
}
return parseInt(base, from).toString(to);
};

先将 base 转为 10 进制,然后再通过 toString()转为对应的进制。

transform(14, 8, 16); // 将8进制的14转为16进制,输出'c'
transform(1011, 2, 16); // 将2进制的1011转为16进制,输出'b'
transform("ff", 16, 2); // 将16进制的‘ff’转为2进制,输出'11111111'

4. 数组类型

数组类型不是基本类型,它会把每项按照上面的规则转为字符串后,以英文逗号,拼接数组的所有项,若数组有多层,则展开所有。

const arr = [
123.45,
() => {
const a = "这是自定义函数";
},
Math.abs,
true,
false,
"abc",
["arr", 1, 2],
null,
undefined,
1,
]; arr.toString(); // '123.45,() => {const a = "这是自定义函数";},function abs() { [native code] },true,false,abc,arr,1,2,,,1'

输出的字符串比较长,不过我们也能发现其中的几个特点:

  1. 这里把数组中的所有项均列了出来,没有更深层的数组;
  2. 英文逗号,拼接展开的所有项;
  3. null 和 undefined 在转为字符串后丢失,但位置还在;

5. 日期对象类型

Date 对象,toString() 方法返回一个表示该对象的字符串。该 toString 方法总是返回一个美式英语日期格式的字符串。若 Date 对象不是合法的日期格式,则会返回Invalid Date

const date = new Date();
date.toString(); // Mon May 27 2024 09:10:33 GMT+0800 (中国标准时间) new Date("2024/13").toString(); // Invalid Date

6. 孪生方法 toLocaleString()

有的类型的数据,支持toLocaleString()方法,返回的数据与toString()稍微有点区别:

6.1 数字类型的数据

会把数字类型的数据转为特定语言环境表示的字符串,不传参则默认是美式英语环境。我们可以利用这个特性,把数字转为带千分位的数字字符串。

(12345).toLocaleString(); // '12,345'
(34566789).toLocaleString(); // '34,566,789'

6.2 Date 对象的数据

将 Date 对象转为本地格式化的字符串;

new Date().toLocaleString(); // '2024/5/27 10:27:04'

7. 总结

toString()不单单是将变量转为字符串那么简单,不同类型的数据使用时,会有不同的效果。

欢迎关注我的公众号:前端小茶馆。

JavaScript 中 toString 的奇妙使用的更多相关文章

  1. javascript中toString和valueOf方法的区别

    toString():将对象转为字符串 valueOf():获取对象的原始值, 1.针对基本类型的变量:如在string,number,boolean类型的变量上调用这两个方法时,直接返回原始值,即变 ...

  2. 在javascript中toString 和valueOf的区别

    1.toString()方法:主要用于Array.Boolean.Date.Error.Function.Number等对象转化为字符串形式.日期类的toString()方法返回一个可读的日期和字符串 ...

  3. Javascript中的valueOf与toString

    基本上,javascript中所有数据类型都拥有valueOf和toString这两个方法,null除外.它们俩解决javascript值运算与显示的问题,本文将详细介绍,有需要的朋友可以参考下. t ...

  4. JavaScript中typeof、toString、instanceof、constructor与in

    JavaScript 是一种弱类型或者说动态语言.这意味着你不用提前声明变量的类型,在程序运行过程中,类型会被自动确定. 这也意味着你可以使用同一个变量保存不同类型的数据. 最新的 ECMAScrip ...

  5. JavaScript Array 对象方法 以及 如何区分javascript中的toString()、toLocaleString()、valueOf()方法

    1.concat() 2.join() 3.pop() 4.push() 5.reverse() 6.shift() 7.unshift() 8.slice() 9.sort() 10.splice( ...

  6. 【JavaScript中typeof、toString、instanceof、constructor与in】

    JavaScript中typeof.toString.instanceof.constructor与in JavaScript 是一种弱类型或者说动态语言.这意味着你不用提前声明变量的类型,在程序运行 ...

  7. javascript中的toString()方法

    javascript中的toString()方法,主要用于Array.Boolean.Date.Error.Function.Number等对象.下面是这些方法的一些解析和简单应用,做个纪律,以作备忘 ...

  8. JavaScript中的valueOf与toString方法

    基本上,所有JS数据类型都拥有valueOf和toString这两个方法,null除外.它们俩解决javascript值运算与显示的问题. JavaScript 的 valueOf() 方法 valu ...

  9. JavaScript中Object.prototype.toString方法的原理

    在JavaScript中,想要判断某个对象值属于哪种内置类型,最靠谱的做法就是通过Object.prototype.toString方法. ? 1 2 var arr = []; console.lo ...

  10. JavaScript中valueOf函数与toString方法

    基本上,所有JS数据类型都拥有valueOf和toString这两个方法,null除外.它们俩解决javascript值运算与显示的问题,本文将详细介绍,有需要的朋友可以参考下   JavaScrip ...

随机推荐

  1. JMeter接口性能测试工具

    博客地址:https://blog.csdn.net/lovesoo/article/details/78579547

  2. ArkUI开发趣味体验,快来抽取限量HarmonyOS专属头像!

    本次ArkUI开发趣味体验活动,将手把手教大家如何在IDE里实操一个ArkUI程序,通过补充缺失代码,成功运行程序开启抽奖功能,抽取个人专属头像,做HarmonyOS第一批数字藏品家! 同时本期提供的 ...

  3. redis 简单整理——redis 准备篇[一]

    前言 简单整理一下redis. 正文 为什么使用redis? 速度快 1.1 内存执行 1.2 c语言编写,速度相对快一些 1.3 单线程,比较符合这种存储模式 2 丰富的数据结构 3 丰富的功能机制 ...

  4. 重新点亮linux 命令树————文本查看vi和vim[五]

    前言 简单整理一下vi和vim,主要介绍一下四种模式. 正文 四种模式分别是: 正常模式(normal-mode) 插入模式(insert-mode) 命令模式(command-mode) 可视模式( ...

  5. arp 的概念解析

    前言 这里基于arp的基础概念,请先看前面那一节. 正文 看图: 和前面一样去解析地址. 以太网目的地址:就是mac地址. 在发送arp包的时候呢,这个mac地址就是全部是1,因为不知道对方地址是啥. ...

  6. 【高级RAG技巧】在大模型知识库问答中增强文档分割与表格提取

    前言 文档分割是一项具有挑战性的任务,它是任何知识库问答系统的基础.高质量的文档分割结果对于显著提升问答效果至关重要,但是目前大多数开源库的处理能力有限. 这些开源的库或者方法缺点大致可以罗列如下: ...

  7. CF1995E Long Inversions(贪心 + 差分)

    见代码 点击查看代码 //背景:夸一下自己,CF1955A~E均是自己想出来的,这道题思路是自己想的,唯一没想到用差分数组维护 //原理:贪心(想最左边的1开始,不可能对其左边包括自己操作了,否则又要 ...

  8. PolarDB开源未来将有哪些新动向?阿里云数据库开源负责人来解答

    简介: 在10月25日由阿里云开发者社区.PolarDB开源社区.infoQ联合举办的「开源人说」第三期--<数据库PolarDB专场>沙龙上,阿里云数据库开源负责人.数据库资深技术专家王 ...

  9. Serverless 时代下微服务应用全托管解决方案

    简介: 本文介绍了 Serverless 时代下微服务的发展以及过程中遇到的相对较复杂的需求,面对这些,阿里云 Serverless 应用引擎 SAE 将"Serverless"的 ...

  10. [Kali] Kali 信息收集

      网络空间测绘. 网络空间测绘是2016年出现的一个概念,主要指用一些技术方法,来探测全球互联网空间上的节点分布情况和网络关系索引,构建全球互联网图谱的一种方法. nmap端口扫描. 子域名爆破. ...