使用 toString() 將任意型別轉成 String
栏目: JavaScript · 发布时间: 4年前
内容简介:實務上常看到 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]
。
+ 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()
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]
。
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]
。
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。
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
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
以上所述就是小编给大家介绍的《使用 toString() 將任意型別轉成 String》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- RecyclerView使用指南(一)—— 基本使用
- 如何使用Meteorjs使用URL参数
- 使用 defer 还是不使用 defer?
- 使用 Typescript 加强 Vuex 使用体验
- [译] 何时使用 Rust?何时使用 Go?
- UDP协议的正确使用场合(谨慎使用)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
极致:互联网时代的产品设计
戴维•罗斯 / 中信出版集团 / 2016-6 / 49.00元
在不远的未来,日常物品将能够迅速理解我们的需求,改善我们的生活,并随处可见。为了实现这一预期,我们需要能够发现用户使用产品的场景,找到用户高频刚需痛点的产品设计者。 站在下一个转型发展的悬崖上,我们看到技术将更具人性。随着物联网的发展,我们习以为常的数百件日常物品:汽车、钱包、手表、雨伞甚至垃圾桶,都将回应我们的需求,了解我们,学习为我们思考。最先出现的智能硬件为什么是智能手环、无人驾驶汽车......一起来看看 《极致:互联网时代的产品设计》 这本书的介绍吧!