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 相关文章推荐
javaScript - 如何引入js代码
Mar 09 Javascript
js更优雅的兼容
Aug 12 Javascript
JQuery文本框高亮显示插件代码
Apr 02 Javascript
JavaScript File分段上传
Mar 10 Javascript
基于javascript的异步编程实例详解
Apr 10 Javascript
微信小程序 实现列表项滑动显示删除按钮的功能
Apr 13 Javascript
React-router中结合webpack实现按需加载实例
May 25 Javascript
微信小程序使用input组件实现密码框功能【附源码下载】
Dec 11 Javascript
Vue.directive()的用法和实例详解
Mar 04 Javascript
angularJs中ng-model-options设置数据同步的方法
Sep 30 Javascript
jQuery操作动画完整实例分析
Jan 10 jQuery
Vue仿百度搜索功能
Dec 28 Vue.js
详解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 获取完整url地址
2008/12/20 PHP
php 分页函数multi() discuz
2009/06/21 PHP
Zend Framework创建自己的动作助手详解
2016/03/05 PHP
PHP微信开发之文本自动回复
2016/06/23 PHP
jquery 结合C#后台的数组对文章的关键字自动添加链接的代码
2011/07/15 Javascript
javascript获取隐藏dom的宽高 具体实现
2013/07/14 Javascript
jquery1.9 下检测浏览器类型和版本的方法
2013/12/26 Javascript
jquery实现左右无缝轮播图
2020/07/31 Javascript
AngularJS基础 ng-keyup 指令简单示例
2016/08/02 Javascript
Angular中使用$watch监听object属性值的变化(详解)
2017/04/24 Javascript
9种使用Chrome Firefox 自带调试工具调试javascript技巧
2017/12/22 Javascript
D3.js实现简洁实用的动态仪表盘的示例
2018/04/04 Javascript
vue配置多页面的实现方法
2018/05/22 Javascript
详解ES6 export default 和 import语句中的解构赋值
2019/05/28 Javascript
vue点击页面空白处实现保存功能
2019/11/06 Javascript
Vue实现鼠标经过文字显示悬浮框效果的示例代码
2020/10/14 Javascript
[44:04]OG vs Mineski 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/18 DOTA
Python多线程学习资料
2012/12/19 Python
python实现dnspod自动更新dns解析的方法
2014/02/14 Python
python基础教程之序列详解
2014/08/29 Python
Python基于twisted实现简单的web服务器
2014/09/29 Python
Python算术运算符实例详解
2017/05/31 Python
Python输出\u编码将其转换成中文的实例
2018/12/15 Python
Python通过Manager方式实现多个无关联进程共享数据的实现
2019/11/07 Python
python 求10个数的平均数实例
2019/12/16 Python
python GUI库图形界面开发之PyQt5时间控件QTimer详细使用方法与实例
2020/02/26 Python
Python 定义只读属性的实现方式
2020/03/05 Python
python字符串判断密码强弱
2020/03/18 Python
IntelliJ 中配置 Anaconda的过程图解
2020/06/01 Python
HTML5的结构和语义(1):前言
2008/10/17 HTML / CSS
印度和世界各地的精美产品:Ikka Dukka
2018/02/12 全球购物
酒店总经理岗位职责范本
2014/08/08 职场文书
2014学习优秀共产党员先进事迹思想汇报
2014/09/14 职场文书
民事辩护词范文
2015/05/21 职场文书
3招让你摆脱即兴讲话冷场尴尬
2019/08/08 职场文书
Python Pandas 删除列操作
2022/03/16 Python