「譯」在JavaScript中將值轉換爲字符串的5種方法

原文: 5 Ways to Convert a Value to String in JavaScriptjavascript

若是您關注Airbnb的樣式指南,首選方法是使用 「String()」👍

它也是我使用的那個,由於它是最明確的 - 讓其餘人輕鬆地遵循你的代碼的意圖🤓java

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

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它會拋出一個TypeErrorspa

若是你很好奇,那就是TypeError: TypeError: Cannot convert a Symbol value to a string3d

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將值轉換爲字符串。並且這裏真的沒有強制發生。所以,您瞭解可用的全部工具。而後你能夠決定使用什麼工具而不是根據具體狀況使用👍code

有一點我想指出,由於你可能沒有注意它。當您在實際string值上使用它時,它會將其更改成帶引號的字符串。cdn

.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(),當你想把一個值轉換爲字符串。除了它會爲undefinednull拋出一個錯誤,其餘表現都很好。因此必定要注意這一點。blog

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()處理nullundefined至關不錯。不會拋出任何錯誤 - 除非這是你想要的。通常來講記住個人建議。您將最瞭解您的應用程序,所以您應該選擇最適合您狀況的方式。

結論:String()🏆

在向您展現了全部不一樣方法如何處理不一樣類型的值以後。但願您瞭解這些差別,而且您將知道下次處理代碼時要使用的工具。若是你不肯定,String()老是一個很好的默認選擇👍

相關文章
相關標籤/搜索