使用 toString() 將任意型別轉成 String

栏目: JavaScript · 发布时间: 6年前

内容简介:實務上常看到 String function、macOS Mojave 10.14.5VS Code 1.36.0

實務上常看到 String function、 + operator 與 toString() 將任意型別轉成 String,但其實都只能處裡 primitive,無法處理 object,使用 Ramda 的 toString() 是更安全的做法。

Version

macOS Mojave 10.14.5

VS Code 1.36.0

Quokka 1.0.233

Ramda 0.26.1

String Function

let data0 = 123;
let data1 = true;
let data2 = { name: 'Sam' };

// toString :: * -> String
let toString = arg => String(arg);

toString(data0); // ?
toString(data1); // ?
toString(data2); // ?

使用 String() 可將 primitive 轉成 string,但 object 則回傳非預期的 [object Object]

使用 toString() 將任意型別轉成 String

+ Operator

let data0 = 123;
let data1 = true;
let data2 = { name: 'Sam' };

// toString :: * -> String
let toString = arg => arg + '';

toString(data0); // ?
toString(data1); // ?
toString(data2); // ?

也可以使用 + '' 將 primitive 轉成 string,但 object 則回傳非預期的 [object Object]

使用 toString() 將任意型別轉成 String

toString()

let data0 = 123;
let data1 = true;
let data2 = { name: 'Sam' };

// toString :: * -> String
let toString = arg => arg.toString();

toString(data0); // ?
toString(data1); // ?
toString(data2); // ?

也可使用 ECMAScript 內建 Number.prototype.toString() 與、 Boolean.prototype.toString() 將 primitive 轉成 string,但 Object.prototype.toString() 則回傳非預期的 [object Object]

使用 toString() 將任意型別轉成 String

Template String

let data0 = 123;
let data1 = true;
let data2 = { name: 'Sam' };

// toString :: * -> String
let toString = arg => `${arg}`;

toString(data0); // ?
toString(data1); // ?
toString(data2); // ?

ES6 迎來 template string,可將 primitive 轉成 string,但 object 則回傳非預期的 [object Object]

使用 toString() 將任意型別轉成 String

JSON.stringify()

let data0 = 123;
let data1 = true;
let data2 = { name: 'Sam' };

// toString :: * -> String
let toString = arg => JSON.stringify(arg);

toString(data0); // ?
toString(data1); // ?
toString(data2); // ?

也可以使用 JSON.stringify() 將 primitive 與 object 都轉成 string。

使用 toString() 將任意型別轉成 String

Ramda

import { toString } from 'ramda';

let data0 = 123;
let data1 = true;
let data2 = { name: 'Sam' };

toString(data0); // ?
toString(data1); // ?
toString(data2); // ?

事實上 Ramda 已經內建 toString() ,可直接使用,結果與 JSON.stringify() 相同。

toString()

* -> String

將任意型別轉成 string

* :data 為任意型別

String :回傳 string

使用 toString() 將任意型別轉成 String

Conclusion

  • JSON.stringify() 與 Ramda 的 toString() 可同時處理 primitive 與 object
  • 實務上建議使用 Ramda 的 toString() ,可讀性最高,且 primitive 與 object 皆可處理

Reference

Dr.Axel Rauschmayer , Speaking JavaScript

Samantha Ming , 5 Ways to Convert a Value to String in JavaScript

Ramda , toString()


以上所述就是小编给大家介绍的《使用 toString() 將任意型別轉成 String》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

微机原理与接口技术

微机原理与接口技术

李文英、李勤、刘星、宋蕴新 / 清华大学出版社 / 2001-9 / 26.00元

《高等院校计算机应用技术规划教材•应用型教材系列•微机原理与接口技术》是“高职高专计算机系列教材”之一。全书包括微机原理、汇编语言、接口技术三部分内容。微机原理部分讲述了80x86的内部结构及工作原理、半导体存储器及其系统、微型机总线结构等。汇编语言部分讲述了指令系统、编程技巧。接口技术部分讲述了中断系统、中断控制器、并行接口、串行接口、DMA控制器、定时器,以及A/D、D/A转换器等常用芯片的硬......一起来看看 《微机原理与接口技术》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换