抖音资讯

douyinzx

js对象转字符串的方法有哪些(js转换为字符串类型)

iseeyu2年前 (2024-05-08)抖音资讯111

如果你订阅了Airbnb 的 JavaScript 风格指南,就会知道最好的方法是使用 "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 错误,除此之外,其他都输出正确的值

js对象转字符串的方法有哪些(js转换为字符串类型)

模板字符串

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

实际上使用模板字符串和拼接字符串是输出相同的结果,再者,当处理 Symbol 这也不是最理想的方式因为它会抛出一个 TypeError

TypeError: Cannot convert a Symbol value to a string

类型错误: 不能把 Symbol 类型的值转换为 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 去把一个值转成字符串,而且这里真的没有强制发生,我主要包括这种方式来完整让你了解可用的所有工具,然后你根据具体情况来挑选使用哪种方式

有个点我要指出来因为你可能没注意,当你使用一个纯字符串格式的值转换出来就会包裹引号

扩展阅读 Kyle Simpson 的 “You Don’t Know JS”: JSON Stringification

关于了解基本原理的重要性

你可能注意到我的代码笔记经常引用 Kyle 的书,我在上面学到了很多东西,我不是来自计算机科学背景,缺乏很多基本概念,他的书让我意识到明白基本原来是多么重要,对于那些想要成为高级工程师的人,真正了解基本原理是提升水平的好方法,否则很难提高。你最终知道了问题在那里,但是如果你知道了基本原理,就会知道为什么从而知道如何去解决,总之,强烈推荐这个系列给那些想成为高级程序员的人!

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

因此对比就留给了 toString 和 String, toString 也执行的不错,一定要注意的一点就是在 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() 处理 undefined 和 null 非常的好 ,不会抛出任何异常。记住我经常说的,你最了解你的程序,因此你应该选择最适合你的方式。

总结

在展示了所有不同的方法如何处理不同类型的值之后,希望你能意识到这些差异并且知道下次处理代码时如何使用,如果你不确认,String()是最好的选择

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://0291.com.cn/post/42600.html

相关文章

抖音下拉宝讲解:抖音seo优化如何操作!

抖音下拉宝讲解:抖音seo优化如何操作!

今天抖音下拉宝免费教你做抖音,抖音优化,其实你根本就不用花钱去找别人学,自己动手就可以做。我们做做了几年,做过各行各业,发现很多人呢,在刚接触抖音seo的时候,不懂得抖音搜索的排序规则。然后呢,花钱找别人做,或者是买课程,其中你遇到靠谱的还好,遇到不靠谱的呢,被坑不说啊,...

公众号菜单怎么添加多篇文章(在子菜单中添加文章的过程)

公众号菜单怎么添加多篇文章(在子菜单中添加文章的过程)

公众号运营者行开始的时候发文都是一篇一篇的推送,看到别的公众号一次能发好几篇,觉得奇怪,研究了一下,原来也不难,只是我们没有找到而已,今天就来分享一下如何一次推送多篇文章   首先我们登录微信公众平台,和写文转载文章一样,找到原创管理--新建图文...

怎么拍抖音才能上热门(最容易涨粉的短视频)

怎么拍抖音才能上热门(最容易涨粉的短视频)

很多人都会发现,随着抖音用户的暴涨,越来越多的人和机构加入战斗,抖音视频的制作门槛越来越高,以前随便拍摄一个东西就能上热门获取几十万点赞,但现在连机器的审核都很难。 1、视频呈现的内容 一开始跟很多人对于对视频内容呈现,呈现的多少是没有概念的,这里小编告诉大家抖音短视频的内容越...

圈粉500万的噶羊少女,竟然还有个小号?

圈粉500万的噶羊少女,竟然还有个小号?

凭借“八分钟嘎一只羊”火了的嘎羊少女,最近在快手,开始了自己的首次直播。 9月2日晚上八点,迎着新疆的夕阳余晖,数万老铁们闻讯而来。 一边就着新疆的大好草原风光,一边和嘎羊少女“云牧羊”,即时退出当代社畜生活; 整场直播下来,直播间的观看人数近700万,喜提新疆地区直播间热...

抖音seo矩阵获客系统是什么?

抖音seo矩阵获客系统是什么?

抖音矩阵获客系统是什么?...

几十个抖音播放量怎么了?抖音播放量低的解决

几十个抖音播放量怎么了?抖音播放量低的解决

几十个抖音播放量怎么了?抖音播放量低的解决方案 几十个抖音播放量怎么了? 如果抖音只有十几个播放量,基本可以断定这个账号是有限的。 对于限流账号,建议直接换号,因为限流或多或少是违规造成的,很难恢复,直接换号会更简单。如果真的不想换号,可以做以下操作试着挽救:...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片