麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

了解在JavaScript中將值轉換為字符串的5種方法

2019-11-19 11:23:04
字體:
來源:轉載
供稿:網友

如果您關注Airbnb的樣式指南,首選方法是使用“String()”

它也是我使用的那個,因為它是最明確的 - 讓其他人輕松地遵循你的代碼的意圖

請記住,最好的代碼不一定是最聰明的方式,它是最能將代碼理解傳達給他人的代碼

const value = 12345;// Concat Empty Stringvalue + '';// Template Strings`${value}`;// JSON.stringifyJSON.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); // undefinedJSON.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(); // TypeErrornullValue.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()總是一個很好的默認選擇

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产毛片aaa一区二区三区视频 | 亚洲午夜免费电影 | 一级黄色免费 | 美女网站黄在线观看 | 欧美 日韩 国产 在线 | 成年免费视频黄网站在线观看 | 欧美成人综合视频 | 国产一区二区三区四区五区在线 | vidz 98hd| 久久99综合| 久久在现视频 | 欧美重口另类videos人妖 | 超碰97最新 | 水多视频在线观看 | h视频在线观看免费 | 久色精品视频 | 国产毛片网站 | 在线成人精品视频 | 免费永久看羞羞片网站入口 | 一级在线 | 精品在线一区二区三区 | 国产羞羞视频在线免费观看 | 国产乱淫a∨片免费观看 | 日本a在线观看 | 国产噜噜噜 | 日日鲁一鲁视频 | 国产伦久视频免费观看视频 | 暴力强行进如hdxxx | 色操网 | 美国人成人在线视频 | 国产91久久久久久 | 日本在线一区二区 | 性爱视频免费 | 娇喘视频在线观看 | 成人三级电影网站 | fc2成人免费人成在线观看播放 | 国产一区二区在线观看视频 | 极品销魂一区二区三区 | 日本教室三级在线看 | 欧美亚成人 | 看黄在线观看 |