javascript 數(shù)組 轉(zhuǎn)換 字符串
javascript數(shù)組轉(zhuǎn)換為字符串是開發(fā)中常用的操作。在處理數(shù)據(jù)時(shí),有時(shí)需要將數(shù)組數(shù)據(jù)轉(zhuǎn)換為字符串傳遞給后端服務(wù)器,又或者在頁面上展示數(shù)據(jù)時(shí)需要將數(shù)組轉(zhuǎn)換為字符串格式進(jìn)行展示。那么在javascript開發(fā)中,如何進(jìn)行數(shù)組轉(zhuǎn)換為字符串操作呢?
數(shù)組轉(zhuǎn)字符串的方式
在javascript中,數(shù)組轉(zhuǎn)換為字符串有兩種方式:toString()和join()方法。
數(shù)組toString()方法
toString()方法是javascript原生提供的一個(gè)方法,能夠?qū)?shù)組中的每一個(gè)元素按照特定的格式轉(zhuǎn)換為一個(gè)字符串。
例如:
var arr = [1, 2, 3];
var str = arr.toString();
console.log(str); //output: "1,2,3"
上面代碼中,定義了一個(gè)數(shù)組arr,通過調(diào)用toString()方法,將數(shù)組轉(zhuǎn)換為字符串格式,輸出結(jié)果為"1,2,3"。
需要注意的是,toString()方法轉(zhuǎn)換的字符串是不包含方括號(hào)的,即只包含元素本身,而不是將整個(gè)數(shù)組轉(zhuǎn)換為一個(gè)字符串。
數(shù)組join()方法
join()方法是數(shù)組提供的另一種將數(shù)組轉(zhuǎn)換為字符串的方式。在使用join()方法時(shí),我們可以自定義元素之間的分隔符。
例如:var arr = [1, 2, 3];
var str = arr.join("-");
console.log(str); //output: "1-2-3"
上面代碼中,定義了一個(gè)數(shù)組arr,通過調(diào)用join()方法,將數(shù)組轉(zhuǎn)換為字符串格式,且元素之間使用"-"連接,輸出結(jié)果為"1-2-3"。
需要注意的是,join()方法的參數(shù)為字符串類型,若不提供參數(shù),則默認(rèn)使用逗號(hào)作為元素之間的分隔符。
數(shù)組轉(zhuǎn)字符串時(shí)的問題
在進(jìn)行數(shù)組轉(zhuǎn)換為字符串操作時(shí),還需要注意一些問題。
若數(shù)組中的元素類型為對(duì)象,則轉(zhuǎn)換成的字符串為字符串格式的"[object Object]"。
例如:var arr = [{name: "xiaoming"}, {name: "xiaohong"}];
var str = arr.toString();
console.log(str); //output: "[object Object],[object Object]"
上面代碼中,定義了一個(gè)數(shù)組arr,內(nèi)容為兩個(gè)對(duì)象。使用toString()方法將數(shù)組轉(zhuǎn)換成了字符串形式,但是輸出的結(jié)果為"[object Object],[object Object]"。
若不想出現(xiàn)這種情況,我們需要使用JSON.stringify進(jìn)行轉(zhuǎn)換。
例如:var arr = [{name: "xiaoming"}, {name: "xiaohong"}];
var str = JSON.stringify(arr);
console.log(str); //output: "[{"name":"xiaoming"},{"name":"xiaohong"}]"
上面代碼中,使用JSON.stringify進(jìn)行轉(zhuǎn)換,輸出的結(jié)果為:"[{"name":"xiaoming"},{"name":"xiaohong"}]",符合我們的預(yù)期。
結(jié)論
數(shù)組轉(zhuǎn)換為字符串是javascript開發(fā)中常用的操作之一,常用的方法有toString()和join()方法,若要避免對(duì)象轉(zhuǎn)換出錯(cuò),可以使用JSON.stringify進(jìn)行轉(zhuǎn)換。在進(jìn)行數(shù)組轉(zhuǎn)換時(shí),我們還需要注意到分隔符的問題,根據(jù)需求進(jìn)行設(shè)置,以達(dá)到更好的效果。