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脚本
Dec 03 Javascript
fckeditor 获取文本框值的实现代码
Feb 09 Javascript
使用js在页面中绘制表格核心代码
Sep 16 Javascript
js获取IFRAME当前的URL的方法
Nov 13 Javascript
javascript中的__defineGetter__和__defineSetter__介绍
Aug 15 Javascript
jquery插件bxslider用法实例分析
Apr 16 Javascript
jQuery实现的导航动画效果(附demo源码)
Apr 01 Javascript
详解webpack 入门与解析
Apr 09 Javascript
如何优雅的在一台vps(云主机)上面部署vue+mongodb+express项目
Jan 20 Javascript
node命令行工具之实现项目工程自动初始化的标准流程
Aug 12 Javascript
iview form清除校验状态的实现
Sep 19 Javascript
vue+springboot+element+vue-resource实现文件上传教程
Oct 21 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+MySQL 手工注入语句大全 推荐
2009/10/30 PHP
PHP笔记之:日期函数的使用介绍
2013/04/24 PHP
jQuery asp.net 用json格式返回自定义对象
2010/04/07 Javascript
瀑布流布局并自动加载实现代码
2013/03/12 Javascript
javascript实用方法总结
2015/02/06 Javascript
网页禁用右键菜单和鼠标拖动选择方法小结
2015/02/25 Javascript
Javascript实现鼠标右键特色菜单
2015/08/04 Javascript
jquery实现最简单的滑动菜单效果代码
2015/09/12 Javascript
Node.js程序中的本地文件操作用法小结
2016/03/06 Javascript
JavaScript仿淘宝页面图片滚动加载及刷新回顶部的方法解析
2016/05/24 Javascript
JS实用的带停顿的逐行文本循环滚动效果实例
2016/11/23 Javascript
vue-cli入门之项目结构分析
2017/04/20 Javascript
Webpack 服务器端代码打包的示例代码
2017/09/19 Javascript
vue.js添加一些触摸事件以及安装fastclick的实例
2018/08/28 Javascript
[26:24]完美副总裁、DOTA2负责人蔡玮专访:电竞如人生
2014/09/11 DOTA
python里对list中的整数求平均并排序
2014/09/12 Python
使用python实现rsa算法代码
2016/02/17 Python
对python的unittest架构公共参数token提取方法详解
2018/12/17 Python
Laravel+Dingo/Api 自定义响应的实现
2019/02/17 Python
Python通过cv2读取多个USB摄像头
2019/08/28 Python
python调用接口的4种方式代码实例
2019/11/19 Python
使用python批量转换文件编码为UTF-8的实现
2020/04/03 Python
python实现登录与注册系统
2020/11/30 Python
HTML5 video循环播放多个视频的方法步骤
2020/08/06 HTML / CSS
我能否用void** 指针作为参数, 使函数按引用接受一般指针
2013/02/16 面试题
高中自我鉴定范文
2013/11/03 职场文书
土木工程毕业生自荐信
2013/11/12 职场文书
挂职自我鉴定
2014/02/26 职场文书
选秀节目策划方案
2014/06/06 职场文书
生产工厂门卫岗位职责
2014/09/26 职场文书
婚前财产协议书范本
2014/10/19 职场文书
本科毕业论文致谢词
2015/05/14 职场文书
2015年小学数学教师工作总结
2015/05/20 职场文书
高一地理教学工作总结
2015/08/12 职场文书
CSS 制作波浪效果的思路
2021/05/18 HTML / CSS
nginx实现多geoserver服务的负载均衡
2022/05/15 Servers