国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

javascript中數(shù)組和字符串的方法對比

2019-11-20 09:26:47
字體:
供稿:網(wǎng)友

前面的話

字符串和數(shù)組有很多的相同之處,它們的方法眾多,且相似度很高;但它們又有不同之處,字符串是不可變值,于是可以把其看作只讀的數(shù)組。本文將對字符串和數(shù)組的類似方法進行比較

可索引

ECMAScript5定義了一種訪問字符的方法,使用方括號加數(shù)字索引來訪問字符串中的特定字符

可索引的字符串的最大的好處就是簡單,用方括號代替了charAt()調(diào)用,這樣更加簡潔、可讀并且可能更高效。不僅如此,字符串的行為類似于數(shù)組的事實使得通用的數(shù)組方法可以應用到字符串上

如果參數(shù)超出范圍或是NaN時,則輸出undefined

var str = "hello";console.log(str[0]);//hconsole.log(str[[1]]);//econsole.log(str[false]);//undefinedconsole.log(str[-1]);//undefinedconsole.log(str[NaN]);//undefinedconsole.log(str[]);//報錯
var arr = ['h','e','l','l','o'];console.log(arr[0]);//hconsole.log(arr[[1]]);//econsole.log(arr[false]);//undefinedconsole.log(arr[-1]);//undefinedconsole.log(arr[NaN]);//undefinedconsole.log(arr[]);//報錯

轉(zhuǎn)換

字符串可以使用split()方法轉(zhuǎn)換為數(shù)組;而數(shù)組可以使用join()方法轉(zhuǎn)換為字符串

【split()】

split()方法基于指定的分隔符將一個字符串分割成多個字符串,并將結(jié)果放在一個數(shù)組中,分隔符可以是字符串,也可以是一個正則表達式

該方法可以接受(可選的)第二個參數(shù)用于指定數(shù)組的大小。如果第二個參數(shù)為0-array.length范圍內(nèi)的值時,按照指定參數(shù)輸出,其他情況將所有結(jié)果都輸出

若指定分隔符沒有出現(xiàn)在字符串中,則以數(shù)組的形式返回原字符串的值

var colorText = 'red,blue,green,yellow';console.log(colorText.split(''));//["r", "e", "d", ",", "b", "l", "u", "e", ",", "g", "r", "e", "e", "n", ",", "y", "e", "l", "l", "o", "w"]console.log(colorText.split(','));//["red", "blue", "green", "yellow"]console.log(colorText.split(',',2));//["red", "blue"]console.log(colorText.split(',',6));//["red", "blue", "green", "yellow"]console.log(colorText.split('-'));//["red,blue,green,yellow"]console.log(colorText.split(//,/));//["red", "blue", "green", "yellow"]console.log(colorText.split(/e/));//["r", "d,blu", ",gr", "", "n,y", "llow"]console.log(colorText.split(/[^/,]+/));//將除去逗號以外的字符串變?yōu)榉指舴鸞"", ",", ",", ",", ""],IE8-會識別為[",",",",","]

【join()】

join()方法可以使用不同的分隔符來構(gòu)建這個字符串,join()方法只接收一個參數(shù),用作分隔符的字符串,然后返回包含所有數(shù)組項的字符串

如果不給join()方法傳入任何值,則使用逗號作為分隔符

var a = [1,2,3];console.log(a.join());//'1,2,3'console.log(a.join(' '));//'1 2 3'console.log(a.join(''));//'123'var b = new Array(10);b.join('-');//'---------',9個連字符組成的字符串

如果數(shù)組中的某一項的值是null或者undefined,則該值在join()方法返回的結(jié)果中以空字符串表示

var colors = [1,undefined,2,null,3];console.log(colors.join());//'1,,2,,3'

由于字符串是類數(shù)組對象,所以,也可以使用join()方法

console.log(Array.prototype.join.call('hello', '-'));// "h-e-l-l-o"
var str = 'test';var arr = str.split('')//["t", "e", "s", "t"]console.log(arr.join('-'));//'t-e-s-t'

拼接  

字符串和數(shù)組共同擁有拼接方法concat()

var value = 'hello';console.log(value.concat('world'));//'helloworld'console.log(value.concat(['world']));//'helloworld'console.log(value.concat([['world']]));//'helloworld'
var value = ['hello'];console.log(value.concat('world'));//["hello", "world"]console.log(value.concat(['world']));//["hello", "world"]console.log(value.concat([['world']]));//["hello", ["world"]]

創(chuàng)建

字符串和數(shù)組都擁有創(chuàng)建方法slice(),分別用于創(chuàng)建子字符串和子數(shù)組

slice()方法基于當前數(shù)組(或字符串)中的一個或多個項創(chuàng)建一個新數(shù)組(或字符串),接受一個或兩個參數(shù),即要返回項的起始和結(jié)束位置,最后返回新數(shù)組(或字符串)

slice(start,end)方法需要兩個參數(shù)start和end,返回這個數(shù)組(或字符串)中從start位置到(但不包含)end位置的一個子數(shù)組(或字符串);如果end為undefined或不存在,則返回從start位置到數(shù)組(或字符串)結(jié)尾的所有項

如果start是負數(shù),則start = max(length + start,0)

如果end是負數(shù),則end = max(length + end,0)

start和end無法交換位置

var numbers = [1,2,3,4,5];console.log(numbers.slice(2));//[3,4,5]console.log(numbers.slice(2,undefined));//[3,4,5]console.log(numbers.slice(2,3));//[3]console.log(numbers.slice(2,1));//[]console.log(numbers.slice(-3));//-3+5=2 -> [3,4,5]console.log(numbers.slice(-8));//max(5 + -8,0)=0 -> [1,2,3,4,5]console.log(numbers.slice(0,-3));//-3+5=2 -> [1,2]console.log(numbers.slice(-2,-1));//-2+5=3;-1+5=4; -> [4]
var stringValue = 'hello world';console.log(stringValue.slice());//'hello world'console.log(stringValue.slice(2));//'llo world'console.log(stringValue.slice(20));//''console.log(stringValue.slice(2,undefined));//'llo world'console.log(stringValue.slice(2,-5));//'llo 'console.log(stringValue.slice(2,-20));//''console.log(stringValue.slice(-2,2));//''console.log(stringValue.slice(-2,-20));//''      console.log(stringValue.slice(-2,20));//'ld'console.log(stringValue.slice(-20,2));//'he'console.log(stringValue.slice(-20,-2));//'hello wor'

位置

字符串和數(shù)組都擁有查找位置的兩個方法:indexOf()和lastIndexOf()。位置方法和中括號[]讀取方法正好相反,一個是通過項查找索引,一個是通過索引查找項

【indexOf()】

indexOf(search,start)方法接收search和start兩個參數(shù),返回search首次出現(xiàn)的位置,如果沒有找到則返回-1

字符串中的search參數(shù)會調(diào)用String()轉(zhuǎn)型函數(shù),將該參數(shù)的非字符串值轉(zhuǎn)換為字符串;而數(shù)組中的search參數(shù)則使用嚴格相等運算符(===)進行比較

不論是數(shù)組還是字符串,第二個參數(shù)start都會隱式調(diào)用Number()轉(zhuǎn)型函數(shù),將start非數(shù)字值(undefined除外)轉(zhuǎn)換為數(shù)值;若忽略該參數(shù)或該參數(shù)為undefined、NaN時,start = 0

若start參數(shù)為負數(shù),字符串的處理是將start=0;而數(shù)組的處理是start = max(0,start+length)

var string = 'hello world world';console.log(string.indexOf('ld'));//9console.log(string.indexOf('ld',undefined));//9console.log(string.indexOf('ld',NaN));//9console.log(string.indexOf('ld',-1));//9console.log(string.indexOf('ld',10));//15console.log(string.indexOf('ld',[10]));//15console.log(string.indexOf('true',[10]));//-1console.log(string.indexOf(false,[10]));//-1
var arr = ['a','b','c','d','e','a','b'];console.log(arr.indexOf('a',undefined));//0console.log(arr.indexOf('a',NaN));//0console.log(arr.indexOf('a',1));//5console.log(arr.indexOf('a',true));//5console.log(arr.indexOf('a',-1));//max(0,-1+7)=6; -1console.log(arr.indexOf('a',-5));//max(0,-5+7)=2; 5console.log(arr.indexOf('a',-50));//max(0,-50+7)=0; 0

【lastIndexOf()】

與indexOf()方法相反,lastIndexOf()方法是從右向左查找

lastIndexOf(search,start)方法接收search和start兩個參數(shù),返回searchString第一次出現(xiàn)的位置,如果沒有找到則返回-1

類似地,字符串中的search參數(shù)會調(diào)用String()轉(zhuǎn)型函數(shù),將該參數(shù)的非字符串值轉(zhuǎn)換為字符串;而數(shù)組中的search參數(shù)則使用嚴格相等運算符(===)進行比較

不論是數(shù)組還是字符串,第二個參數(shù)start都會隱式調(diào)用Number()轉(zhuǎn)型函數(shù),將start非數(shù)字值(undefined除外)轉(zhuǎn)換為數(shù)值

若忽略該參數(shù)或該參數(shù)為undefined、NaN時,字符串的處理是start = length - 1;而數(shù)組的處理是start = 0

若start參數(shù)為負數(shù),字符串的處理是將start=0;而數(shù)組的處理是start = max(0,start+length)

var string = 'hello world world';console.log(string.lastIndexOf('ld'));//15console.log(string.lastIndexOf('ld',undefined));//15console.log(string.lastIndexOf('ld',NaN));//15console.log(string.lastIndexOf('ld',-1));//-1console.log(string.lastIndexOf('h',-1));//0console.log(string.lastIndexOf('w',undefined));//12console.log(string.lastIndexOf('ld',10));//9console.log(string.lastIndexOf('ld',[10]));//9console.log(string.lastIndexOf('true',[10]));//-1console.log(string.lastIndexOf(false,[10]));//-1
var arr = [1,2,3,'1','2','3'];console.log(arr.lastIndexOf('2'));//4console.log(arr.lastIndexOf(3));//2console.log(arr.lastIndexOf(0));//-1var arr = ['a','b','c','d','e','a','b'];console.log(arr.lastIndexOf('b'));//6console.log(arr.lastIndexOf('b',undefined));//-1console.log(arr.lastIndexOf('a',undefined));//0console.log(arr.lastIndexOf('b',NaN));//-1console.log(arr.lastIndexOf('b',1));//1console.log(arr.lastIndexOf('b',-1));//max(0,-1+7)=6; 6console.log(arr.lastIndexOf('b',-5));//max(0,-5+7)=2; 1console.log(arr.lastIndexOf('b',-50));//max(0,-50+7)=0; -1

以上這篇javascript中數(shù)組和字符串的方法對比就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 茌平县| 洪泽县| 城固县| 泸州市| 德庆县| 通榆县| 浙江省| 和林格尔县| 鹤壁市| 开阳县| 大邑县| 金沙县| 清流县| 江城| 泰来县| 南充市| 南京市| 彩票| 大化| 临猗县| 四会市| 广河县| 利辛县| 澄江县| 屯门区| 翁源县| 小金县| 鲜城| 峨边| 塘沽区| 合水县| 和硕县| 綦江县| 保山市| 巴林右旗| 普格县| 宜君县| 山西省| 富锦市| 汕头市| 嘉禾县|