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

了解在JavaScript中將值轉(zhuǎn)換為字符串的5種方法

 更新時間:2019年06月06日 11:50:46   作者:Ioodu  
這篇文章主要介紹了在JavaScript中將值轉(zhuǎn)換為字符串的5種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,下面小編就和大家一起來學(xué)習(xí)下吧

如果您關(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值上使用它時,它會將其更改為帶引號的字符串。

.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()

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 用JS獲得表格當(dāng)前行數(shù)的代碼

    用JS獲得表格當(dāng)前行數(shù)的代碼

    用JS獲得表格當(dāng)前行數(shù)的代碼...
    2007-01-01
  • 前端防止用戶重復(fù)提交js實(shí)現(xiàn)代碼示例

    前端防止用戶重復(fù)提交js實(shí)現(xiàn)代碼示例

    這篇文章主要給大家介紹了關(guān)于前端防止用戶重復(fù)提交js實(shí)現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起看看吧
    2018-09-09
  • 微信小程序?qū)崿F(xiàn)炫酷的彈出式菜單特效

    微信小程序?qū)崿F(xiàn)炫酷的彈出式菜單特效

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)炫酷的彈出式菜單特效,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • aspx中利用js實(shí)現(xiàn)確認(rèn)刪除代碼

    aspx中利用js實(shí)現(xiàn)確認(rèn)刪除代碼

    在一些程序開發(fā)中,對于刪除操作,最好再讓用戶確認(rèn)一下,以免誤操作,帶來的損失,下面的方法,大家可以參考下。各個語言下,都通用的思路。
    2010-07-07
  • layui動態(tài)設(shè)置單選按鈕選中效果實(shí)例

    layui動態(tài)設(shè)置單選按鈕選中效果實(shí)例

    最近在使用layui前端框架,在使用單選按鈕、下拉菜單select、checkbox等控件的時候,往往遇到一些初始化的東西,下面這篇文章主要給大家介紹了關(guān)于layui動態(tài)設(shè)置單選按鈕選中效果的相關(guān)資料,需要的朋友可以參考下
    2023-06-06
  • 自用js開發(fā)框架小成 學(xué)習(xí)js的朋友可以看看

    自用js開發(fā)框架小成 學(xué)習(xí)js的朋友可以看看

    前段時間項(xiàng)目需要用到j(luò)s樹,找了好多都不符合項(xiàng)目需求,后來發(fā)現(xiàn)了梅花雪樹和js框架,類似C#名稱空間的用法讓我眼前一亮,遂拿來主義,讀了幾遍代碼后就開工了(我是個急性子呵呵),完成了大部分,最近才找出來測試了下。
    2010-11-11
  • 利用JavaScript檢測CPU使用率自己寫的

    利用JavaScript檢測CPU使用率自己寫的

    這篇文章主要介紹了自己寫的一個利用JavaScript檢測CPU使用率的方法,需要的朋友可以參考下
    2014-03-03
  • 微信小程序后端(java)開發(fā)流程的詳細(xì)步驟

    微信小程序后端(java)開發(fā)流程的詳細(xì)步驟

    這篇文章主要介紹了微信小程序后端開發(fā)流程的詳細(xì)步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • 詳解JavaScript設(shè)計(jì)模式中的享元模式

    詳解JavaScript設(shè)計(jì)模式中的享元模式

    享元模式是一種用于性能優(yōu)化的模式。享元模式的核心是運(yùn)用共享技術(shù)來有效支持大量細(xì)粒度的對象.如果系統(tǒng)中創(chuàng)建了大量類似的對象而導(dǎo)致內(nèi)存占用過高,本文通過介紹書中文件上傳的優(yōu)化案例來說明享元模式的使用方式和作用,需要的朋友可以參考下
    2023-06-06
  • Javascript 獲取鼠標(biāo)當(dāng)前的位置實(shí)現(xiàn)方法

    Javascript 獲取鼠標(biāo)當(dāng)前的位置實(shí)現(xiàn)方法

    這篇文章主要介紹了Javascript 獲取鼠標(biāo)當(dāng)前的位置實(shí)現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下
    2016-10-10

最新評論