JavaScript中将值转换为字符串的五种方法总结


Posted in Javascript onJune 06, 2019

前言

如果您关注Airbnb的样式指南,首选方法是使用“String()”?

它也是我使用的那个,因为它是最明确的 - 让其他人轻松地遵循你的代码的意图?

请记住,最好的代码不一定是最聪明的方式,它是最能将代码理解传达给他人的代码?

const value = 12345;
// Concat Empty String
value + '';
// Template Strings
`${value}`;
// JSON.stringify
JSON.stringify(value);
// toString()
value.toString();
// String()
String(value);
// RESULT
// '12345'

比较5种方式

好吧,让我们用不同的值测试5种方式。以下是我们要对其进行测试的变量:

const string = "hello";
const number = 123;
const boolean = true;
const array = [1, "2", 3];
const object = {one: 1 };
const symbolValue = Symbol('123');
const undefinedValue = undefined;
const nullValue = null;

结合空字符串

string + ''; // 'hello'
number + ''; // '123'
boolean + ''; // 'true'
array + ''; // '1,2,3'
object + ''; // '[object Object]'
undefinedValue + ''; // 'undefined'
nullValue + ''; // 'null'
// ⚠️
symbolValue + ''; // ❌ TypeError

从这里,您可以看到如果值为一个Symbol ,此方法将抛出TypeError。否则,一切看起来都不错。

模板字符串

`${string}`; // 'hello'
`${number}`; // '123'
`${boolean}`; // 'true'
`${array}`; // '1,2,3'
`${object}`; // '[object Object]'
`${undefinedValue}`; // 'undefined'
`${nullValue}`; // 'null'
// ⚠️
`${symbolValue}`; // ❌ TypeError

使用模版字符串的结果与结合空字符串的结果基本相同。同样,这可能不是理想的处理方式,因为Symbol它会抛出一个TypeError。

如果你很好奇,那就是TypeError: TypeError: Cannot convert a Symbol value to a string

JSON.stringify()

// ⚠️
JSON.stringify(string); // '"hello"'
JSON.stringify(number); // '123'
JSON.stringify(boolean); // 'true'
JSON.stringify(array); // '[1,"2",3]'
JSON.stringify(object); // '{"one":1}'
JSON.stringify(nullValue); // 'null'
JSON.stringify(symbolValue); // undefined
JSON.stringify(undefinedValue); // undefined

因此,您通常不会使用JSON.stringify将值转换为字符串。而且这里真的没有强制发生。因此,您了解可用的所有工具。然后你可以决定使用什么工具而不是根据具体情况使用?

有一点我想指出,因为你可能没有注意它。当您在实际string值上使用它时,它会将其更改为带引号的字符串。

.toString()

string.toString(); // 'hello'
number.toString(); // '123'
boolean.toString(); // 'true'
array.toString(); // '1,2,3'
object.toString(); // '[object Object]'
symbolValue.toString(); // 'Symbol(123)'
// ⚠️
undefinedValue.toString(); // ❌ TypeError
nullValue.toString(); // ❌ TypeError

所以PK其实就是在toString()和String(),当你想把一个值转换为字符串。除了它会为undefined和null抛出一个错误,其他表现都很好。所以一定要注意这一点。

String()

String(string); // 'hello'
String(number); // '123'
String(boolean); // 'true'
String(array); // '1,2,3'
String(object); // '[object Object]'
String(symbolValue); // 'Symbol(123)'
String(undefinedValue); // 'undefined'
String(nullValue); // 'null'

好吧,我想我们找到了胜利者?

正如你所看到的,String()处理null和undefined相当不错。不会抛出任何错误 - 除非这是你想要的。一般来说记住我的建议。您将最了解您的应用程序,因此您应该选择最适合您情况的方式。

结论:String()?

在向您展示了所有不同方法如何处理不同类型的值之后。希望您了解这些差异,并且您将知道下次处理代码时要使用的工具。如果你不确定,String()总是一个很好的默认选择?

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
论坛特效代码收集(落伍转发-不错)
Dec 02 Javascript
javaScript 读取和设置文档元素的样式属性
Apr 14 Javascript
javascript获取当前日期时间及其它操作函数
Jan 11 Javascript
读jQuery之七 判断点击了鼠标哪个键的代码
Jun 21 Javascript
深入理解Javascript动态方法调用与参数修改的问题
Dec 10 Javascript
js数组如何添加json数据及js数组与json的区别
Oct 27 Javascript
jQuery+ajax实现文章点赞功能的方法
Dec 31 Javascript
改变checkbox默认选中状态及取值的实现代码
May 26 Javascript
js删除Array数组中指定元素的两种方法
Aug 03 Javascript
微信小程序-横向滑动scroll-view隐藏滚动条
Apr 20 Javascript
vue checkbox 全选 数据的绑定及获取和计算方法
Feb 09 Javascript
Element Notification通知的实现示例
Jul 27 Javascript
详解Vue 如何监听Array的变化
Jun 06 #Javascript
js常见遍历操作小结
Jun 06 #Javascript
vue中v-show和v-if的异同及v-show用法
Jun 06 #Javascript
vue中的过滤器实例代码详解
Jun 06 #Javascript
Vue响应式原理Observer、Dep、Watcher理解
Jun 06 #Javascript
原生js通过一行代码实现简易轮播图
Jun 05 #Javascript
解决IOS端微信H5页面软键盘弹起后页面下方留白的问题
Jun 05 #Javascript
You might like
PHP4之真OO
2006/10/09 PHP
模仿OSO的论坛(二)
2006/10/09 PHP
php截取视频指定帧为图片
2016/05/16 PHP
PHP数据库操作四:mongodb用法分析
2017/08/16 PHP
javascript编程起步(第五课)
2007/02/27 Javascript
FileUpload上传图片(图片不变形)
2010/08/05 Javascript
jQuery中需要注意的细节问题小结
2011/12/06 Javascript
如何制作浮动广告 JavaScript制作浮动广告代码
2012/12/30 Javascript
关于编写性能高效的javascript事件的技术
2014/11/28 Javascript
jquery实现仿JqueryUi可拖动的DIV实例
2015/07/31 Javascript
分享有关jQuery中animate、slide、fade等动画的连续触发、滞后反复执行的bug
2016/01/10 Javascript
全面了解js中的script标签
2016/07/04 Javascript
总结Javascript中的隐式类型转换
2016/08/24 Javascript
JS无缝滚动效果实现方法分析
2016/12/21 Javascript
js实现悬浮窗效果(支持拖动)
2017/03/09 Javascript
react系列从零开始_简单谈谈react
2017/07/06 Javascript
关于vue.extend和vue.component的区别浅析
2017/08/16 Javascript
认识jQuery的Promise的具体使用方法
2017/10/10 jQuery
jQuery中图片展示插件highslide.js的简单dom
2018/04/22 jQuery
通过nodejs 服务器读取HTML文件渲染到页面的方法
2018/05/17 NodeJs
Vue+Node实现的商城用户管理功能示例
2019/12/23 Javascript
解决vue项目本地启动时无法携带cookie的问题
2021/02/06 Vue.js
Python实现读取及写入csv文件的方法示例
2018/01/12 Python
python表格存取的方法
2018/03/07 Python
Python logging模块用法示例
2018/08/28 Python
浅谈python在提示符下使用open打开文件失败的原因及解决方法
2018/11/30 Python
python读取几个G的csv文件方法
2019/01/07 Python
举例讲解Python常用模块
2019/03/08 Python
python开发实例之python使用Websocket库开发简单聊天工具实例详解(python+Websocket+JS)
2020/03/18 Python
Python 如何查找特定类型文件
2020/08/17 Python
html5响应式开发自动计算fontSize的方法
2020/01/13 HTML / CSS
Feelunique澳大利亚:欧洲的化妆品零售电商
2019/12/18 全球购物
一个大学生十年的职业规划
2014/01/17 职场文书
《千年梦圆在今朝》教学反思
2014/02/24 职场文书
2014年基层党组织公开承诺书
2014/03/29 职场文书
小程序wx.getUserProfile接口的具体使用
2021/06/02 Javascript