欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript中將值轉(zhuǎn)換為字符串的五種方法總結(jié)

 更新時(shí)間:2019年06月06日 09:36:33   作者:Ioodu  
這篇文章主要給大家總結(jié)介紹了關(guān)于JavaScript中將值轉(zhuǎn)換為字符串的五種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

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

它也是我使用的那個(gè),因?yàn)樗亲蠲鞔_的 - 讓其他人輕松地遵循你的代碼的意圖🤓

請(qǐng)記住,最好的代碼不一定是最聰明的方式,它是最能將代碼理解傳達(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種方式

好吧,讓我們用不同的值測(cè)試5種方式。以下是我們要對(duì)其進(jìn)行測(cè)試的變量:

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

從這里,您可以看到如果值為一個(gè)Symbol ,此方法將拋出TypeError。否則,一切看起來(lái)都不錯(cuò)。

模板字符串

`${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它會(huì)拋出一個(gè)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

因此,您通常不會(huì)使用JSON.stringify將值轉(zhuǎn)換為字符串。而且這里真的沒(méi)有強(qiáng)制發(fā)生。因此,您了解可用的所有工具。然后你可以決定使用什么工具而不是根據(jù)具體情況使用👍

有一點(diǎn)我想指出,因?yàn)槟憧赡軟](méi)有注意它。當(dāng)您在實(shí)際string值上使用它時(shí),它會(huì)將其更改為帶引號(hào)的字符串。

.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)你想把一個(gè)值轉(zhuǎn)換為字符串。除了它會(huì)為undefined和null拋出一個(gè)錯(cuò)誤,其他表現(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)不錯(cuò)。不會(huì)拋出任何錯(cuò)誤 - 除非這是你想要的。一般來(lái)說(shuō)記住我的建議。您將最了解您的應(yīng)用程序,因此您應(yīng)該選擇最適合您情況的方式。

結(jié)論:String()🏆

在向您展示了所有不同方法如何處理不同類(lèi)型的值之后。希望您了解這些差異,并且您將知道下次處理代碼時(shí)要使用的工具。如果你不確定,String()總是一個(gè)很好的默認(rèn)選擇👍

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • 微信小程序發(fā)送短信驗(yàn)證碼完整實(shí)例

    微信小程序發(fā)送短信驗(yàn)證碼完整實(shí)例

    這篇文章主要介紹了微信小程序發(fā)送短信驗(yàn)證碼完整實(shí)例,實(shí)現(xiàn)發(fā)送短信驗(yàn)證碼,帶60秒倒計(jì)時(shí)功能,無(wú)需服務(wù)器端,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2019-01-01
  • js+html5 canvas實(shí)現(xiàn)ps鋼筆摳圖

    js+html5 canvas實(shí)現(xiàn)ps鋼筆摳圖

    這篇文章主要介紹了js+html5 canvas實(shí)現(xiàn)ps鋼筆摳圖,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • Javascript的各種節(jié)點(diǎn)操作實(shí)例演示代碼

    Javascript的各種節(jié)點(diǎn)操作實(shí)例演示代碼

    實(shí)例演示對(duì)javascript的節(jié)點(diǎn)的各種操作。包括hasChildNodes(),removeChild(),appendChild(),replaceChild(),insertBefore(),cloneNode()等
    2012-06-06
  • JavaScript實(shí)現(xiàn)顯示和隱藏圖片

    JavaScript實(shí)現(xiàn)顯示和隱藏圖片

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)顯示和隱藏圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • js生成隨機(jī)數(shù)的過(guò)程解析

    js生成隨機(jī)數(shù)的過(guò)程解析

    這篇文章主要介紹了js生成隨機(jī)數(shù)的過(guò)程,如何生成[n,m]的隨機(jī)整數(shù),感興趣的小伙伴們可以參考一下
    2015-11-11
  • JavaScript類(lèi)的繼承方法小結(jié)【組合繼承分析】

    JavaScript類(lèi)的繼承方法小結(jié)【組合繼承分析】

    這篇文章主要介紹了JavaScript類(lèi)的繼承方法,結(jié)合實(shí)例形式總結(jié)分析了JavaScript繼承的概念、原理及組合繼承相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2018-07-07
  • 原生js實(shí)現(xiàn)類(lèi)似彈窗抖動(dòng)效果

    原生js實(shí)現(xiàn)類(lèi)似彈窗抖動(dòng)效果

    這篇文章主要介紹了原生js實(shí)現(xiàn)類(lèi)似彈窗抖動(dòng)效果的相關(guān)資料,推薦給大家,需要的朋友可以參考下
    2015-04-04
  • 詳解Typescript 內(nèi)置的模塊導(dǎo)入兼容方式

    詳解Typescript 內(nèi)置的模塊導(dǎo)入兼容方式

    這篇文章主要介紹了詳解Typescript 內(nèi)置的模塊導(dǎo)入兼容方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • 淺談JavaScript中this的指向問(wèn)題

    淺談JavaScript中this的指向問(wèn)題

    這篇文章主要介紹了淺談JavaScript中this的指向問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • JS實(shí)現(xiàn)圖片輪播跑馬燈

    JS實(shí)現(xiàn)圖片輪播跑馬燈

    這篇文章主要為大家詳細(xì)介紹了原生JS實(shí)現(xiàn)圖片輪播跑馬燈效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07

最新評(píng)論