這篇文章給大家介紹JavaScript中怎么將值轉(zhuǎn)換為字符串,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

扶溝網(wǎng)站制作公司哪家好,找成都創(chuàng)新互聯(lián)公司!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。成都創(chuàng)新互聯(lián)公司從2013年開始到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選成都創(chuàng)新互聯(lián)公司。
前言
如果您關(guān)注Airbnb的樣式指南,首選方法是使用“String()”?
它也是我使用的那個,因?yàn)樗亲蠲鞔_的 - 讓其他人輕松地遵循你的代碼的意圖?
請記住,最好的代碼不一定是最聰明的方式,它是最能將代碼理解傳達(dá)給他人的代碼?
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種方式。以下是我們要對其進(jìn)行測試的變量:
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;結(jié)合空字符串
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使用模版字符串的結(jié)果與結(jié)合空字符串的結(jié)果基本相同。同樣,這可能不是理想的處理方式,因?yàn)镾ymbol它會拋出一個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將值轉(zhuǎn)換為字符串。而且這里真的沒有強(qiáng)制發(fā)生。因此,您了解可用的所有工具。然后你可以決定使用什么工具而不是根據(jù)具體情況使用?
有一點(diǎn)我想指出,因?yàn)槟憧赡軟]有注意它。當(dāng)您在實(shí)際string值上使用它時(shí),它會將其更改為帶引號的字符串。
.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其實(shí)就是在toString()和String(),當(dāng)你想把一個值轉(zhuǎn)換為字符串。除了它會為undefined和null拋出一個錯誤,其他表現(xiàn)都很好。所以一定要注意這一點(diǎn)。
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相當(dāng)不錯。不會拋出任何錯誤 - 除非這是你想要的。一般來說記住我的建議。您將最了解您的應(yīng)用程序,因此您應(yīng)該選擇最適合您情況的方式。
結(jié)論:String()?
在向您展示了所有不同方法如何處理不同類型的值之后。希望您了解這些差異,并且您將知道下次處理代碼時(shí)要使用的工具。如果你不確定,String()總是一個很好的默認(rèn)選擇?
關(guān)于JavaScript中怎么將值轉(zhuǎn)換為字符串就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
分享名稱:JavaScript中怎么將值轉(zhuǎn)換為字符串
轉(zhuǎn)載注明:http://www.chinadenli.net/article48/gpdoep.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供域名注冊、網(wǎng)站設(shè)計(jì)、微信公眾號、標(biāo)簽優(yōu)化、小程序開發(fā)、搜索引擎優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)