首頁 >web前端 >js教程 >js中函數slice,splice和split有什麼差別

js中函數slice,splice和split有什麼差別

一个新手
一个新手原創
2017-09-09 10:49:062549瀏覽

每次遇到這三個數值都感覺好懵。每次都很難區分他們。都不知道用那個。終於今天來總結下。

  1. slice()
    注意:此方法不會改變原始數組。參數含頭不含未
    arrayObject.slice(start,end);
    既可以截取字串也可以截取陣列。傳回的是一個新數組。
    slice() 方法可從現有的陣列中傳回選定的元素。
    傳回一個新的數組,。參數start是截取的開始數組索引,end參數等於你要取的最後一個字元的位置值加上1(可選)(含頭不含未)
    如果第二個參數省略則預設為截取字段從起始位置到結束位置
    如:

`//如果不传入参数二,那么将从参数一的索引位置开始截取,一直到数组尾
 var a=[1,2,3,4,5,6]; 
 var b=a.slice(0,3);  //[1,2,3] 
 var c=a.slice(3);    //[4,5,6]
//如果两个参数中的任何一个是负数,array.length会和它们相加,试图让它们成为非负数,举例说明: //当只传入一个参数,且是负数时,length会与参数相加,然后再截取 
var a=[1,2,3,4,5,6]; var b=a.slice(-1);  //[6]
//当只传入一个参数,是负数时,并且参数的绝对值大于数组length时,会截取整个数组
var a=[1,2,3,4,5,6];
var b=a.slice(-6);  //[1,2,3,4,5,6]
var c=a.slice(-8);  //[1,2,3,4,5,6]//当传入两个参数一正一负时,length也会先于负数相加后,再截取
var a=[1,2,3,4,5,6];var b=a.slice(2,-3);  //[3]//当传入一个参数,大于length时,将返回一个空数组
var a=[1,2,3,4,5,6];var b=a.slice(6);  //[]//截取一个字符串时var a="i am a boy";
var b=a.slice(0,6);  //"i am a"`

#2 splice()
arrayObject.splice(index,howmany,item1,….. ,itemX);
splice() 方法向/從陣列中新增/刪除項目,然後傳回被刪除的項目。
注意:此方法會改變原始陣列。
第一個,第二個參數為必填。而且會根據第二個參數是否為0而有所不同。
如下
第一個參數為起始位置規定新增/刪除項目的位置,使用負數可從陣列結尾規定位置。
第二個參數為要刪除的項目數。如果設定為0,則不會刪除項目
1.刪除-用於刪除元素,兩個參數,第一個參數(要刪除第一項的位置),第二個參數(要刪除的項數).

var lang = ['php', 'java', 'javascript'];  
var removed = lang.splice(1,1); //删除  
console.log(lang); // php, javascript  
console.log(removed); //java

2.插入-向陣列指定位置插入任意項元素。三個參數,第一參數(真實位置),第二個參數(0),第三個參數(插入的項)。

var insert = lang.splice(0, 0, 'asp'); //从第0个位置开始插入  
console.log(insert); //空数组  
console.log(lang); //asp, php,javascript

3.替換-向陣列指定位置插入任意項元素,同時刪除任意數量的項,三個參數。第一個參數(起始位置),第二個參數(刪除的項數),第三個參數(插入任意數量的項)。

var replace = lang.splice(1,1,"c#","ruby"); //删除一项,插入两项  
console.log(lang);  //console.log(replace); //返回删除的项
split(); 
stringObject.split(separator,howmany)

注意:如果把空字串 (“”) 用作 separator,那麼 stringObject 中的每個字元之間都會被分割。 String.split() 執行的動作與 Array.join 執行的動作是相反的。
用來把一個字串分割成字串陣列。一個字串數組。該數組是透過在 separator 指定的邊界處將字串 stringObject 分割成子字串建立的。傳回的陣列中的字符串不包括 separator 本身。
但是,如果 separator 是包含子表達式的正規表示式,那麼傳回的陣列中包含與這些子表達式相符的字串(但不包括與整個正規表示式相符的文字)。
1、如果用“.”作為分隔的話,必須是如下寫法:String.split(“\.”),這樣才能正確的分隔開,不能用String.split(“.”);  
2.如果用「|」當分隔的話,必須是如下寫法:String.split(“\|”),這樣才能正確的分隔開,不能用String.split(“|”);  
3 、如果用“\”作為分隔的話,必須是如下寫法:String.split(\),這樣才能正確的分隔開,不能用String.split(“\”);  
“.”,“| 」和「\」都是轉義字符,必須得加」\”;  
3、如果在一個字串中有多個分隔符,可以用「|」作為連字符,例如:「acount=? and uu =? or n=?”,把三個都分隔出來,可以用String.split(“and|or”);

var str="How are you doing today?" document.write(str.split(" ") + "<br />") 
document.write(str.split("") + "<br />") 
document.write(str.split(" ",3)) 

</script>输出: 

How,are,you,doing,today? 
H,o,w, ,a,r,e, ,y,o,u, ,d,o,i,n,g, ,t,o,d,a,y,? 
How,are,you例子 2 在本例中,我们将分割结构更为复杂的字符串: 

"2:3:4:5".split(":")    //将返回["2", "3", "4", "5"] 
"|a|b|c".split("|") //将返回["", "a", "b", "c", ""] 
例子 3 使用下面的代码,可以把句子分割成单词: 

var words = sentence.split(&#39; &#39;)或者使用正则表达式作为 separator: 

var words = sentence.split(/\s+/)例子 4 如果您希望把单词分割为字母,或者把字符串分割为字符,可使用下面的代码: 

"hello".split("")   //可返回 ["h", "e", "l", "l", "o"]若只需要返回一部分字符,请使用 howmany 参数: 

"hello".split("", 3)    //可返回 ["h", "e", "l"]

以上是js中函數slice,splice和split有什麼差別的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn