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 相关文章推荐
灵活应用js调试技巧解决样式问题的步骤分享
Mar 15 Javascript
使用typeof判断function是否存在于上下文
Aug 14 Javascript
jQuery中append()方法用法实例
Dec 25 Javascript
jquery+CSS实现的多级竖向展开树形TRee菜单效果
Aug 24 Javascript
JavaScript实现搜索框的自动完成功能(一)
Feb 25 Javascript
JS基于ocanvas插件实现的简单画板效果代码(附demo源码下载)
Apr 05 Javascript
浅谈js和css内联外联注意事项
Jun 30 Javascript
express+mockjs实现模拟后台数据发送功能
Jan 07 Javascript
angular4 获取wifi列表中文显示乱码问题的解决
Oct 20 Javascript
jquery使用FormData实现异步上传文件
Oct 25 jQuery
Vue中父子组件的值传递与方法传递
Sep 28 Javascript
详解微信小程序轨迹回放实现及遇到的坑
Feb 02 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
PHP简洁函数小结
2011/08/12 PHP
PHP实现的微信公众号扫码模拟登录功能示例
2019/05/30 PHP
Yii框架getter与setter方法功能与用法分析
2019/10/22 PHP
PHP实现新型冠状病毒疫情实时图的实例
2020/02/04 PHP
简单的jquery拖拽排序效果实现代码
2011/09/20 Javascript
jQuery方法简洁实现隔行换色及toggleClass的使用
2013/03/15 Javascript
基于javascipt-dom编程 table对象的使用
2013/04/22 Javascript
jQuery之尺寸调整组件的深入解析
2013/06/19 Javascript
JScript分割字符串示例代码
2013/09/04 Javascript
javascript验证上传文件的类型限制必须为某些格式
2013/11/14 Javascript
基于socket.io和node.js搭建即时通信系统
2014/07/30 Javascript
JavaScript针对网页节点的增删改查用法实例
2015/02/02 Javascript
Bootstrap Fileinput文件上传组件用法详解
2016/05/10 Javascript
jQuery基础知识点总结(DOM操作)
2016/06/01 Javascript
基于Vue 2.0的模块化前端 UI 组件库小结
2017/12/21 Javascript
30分钟快速入门掌握ES6/ES2015的核心内容(上)
2018/04/18 Javascript
javascript显示动态时间的方法汇总
2018/07/06 Javascript
Vue 事件处理操作实例详解
2019/03/05 Javascript
layui输入框只允许输入中文且判断长度的例子
2019/09/18 Javascript
python使用datetime模块计算各种时间间隔的方法
2015/03/24 Python
Python变量作用范围实例分析
2015/07/07 Python
Python实现登录接口的示例代码
2017/07/21 Python
Python中序列的修改、散列与切片详解
2017/08/27 Python
python如何使用正则表达式的前向、后向搜索及前向搜索否定模式详解
2017/11/08 Python
wxpython绘制圆角窗体
2019/11/18 Python
pandas实现DataFrame显示最大行列,不省略显示实例
2019/12/26 Python
python3 deque 双向队列创建与使用方法分析
2020/03/24 Python
屈臣氏乌克兰:Watsons UA
2019/10/29 全球购物
远程培训的心得体会
2014/09/01 职场文书
导游词之杭州西湖
2019/09/19 职场文书
golang 实现时间戳和时间的转化
2021/05/07 Golang
Go 在 MongoDB 中常用查询与修改的操作
2021/05/07 Golang
python设置 matplotlib 正确显示中文的四种方式
2021/05/10 Python
JavaScript中document.activeELement焦点元素介绍
2021/11/27 Javascript
PostGIS的安装与入门使用指南
2022/01/18 PostgreSQL
python数字图像处理数据类型及颜色空间转换
2022/06/28 Python