這篇文章主要為大家詳細介紹了javascript中不易分清的slice,splice和split三個函數(shù),感興趣的小伙伴們可以參考一下
每每見到這三個函數(shù),我都會很懵,一定要到網(wǎng)上搜搜;今天,恰巧又見到了它們,所以想必是時候為它們做個筆記啦
1.slice(數(shù)組)
用法:array.slice(start,end)
解釋:該方法是對數(shù)組進行部分截取,并返回一個數(shù)組副本;參數(shù)start是截取的開始數(shù)組索引,end參數(shù)等于你要取的最后一個字符的位置值加上1(可選)
//如果不傳入?yún)?shù)二,那么將從參數(shù)一的索引位置開始截取,一直到數(shù)組尾
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]
//如果兩個參數(shù)中的任何一個是負數(shù),array.length會和它們相加,試圖讓它們成為非負數(shù),舉例說明:
//當只傳入一個參數(shù),且是負數(shù)時,length會與參數(shù)相加,然后再截取
var a=[1,2,3,4,5,6];
var b=a.slice(-1); //[6]
//當只傳入一個參數(shù),是負數(shù)時,并且參數(shù)的絕對值大于數(shù)組length時,會截取整個數(shù)組
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]
//當傳入兩個參數(shù)一正一負時,length也會先于負數(shù)相加后,再截取
var a=[1,2,3,4,5,6];
var b=a.slice(2,-3); //[3]
//當傳入一個參數(shù),大于length時,將返回一個空數(shù)組
var a=[1,2,3,4,5,6];
var b=a.slice(6); //[]
2.slice(字符串)
用法:string.slice(start,end)
解釋:slice方法復制string的一部分來構(gòu)造一個新的字符串,用法與參數(shù)勻和數(shù)組的slice方法一樣;end參數(shù)等于你要取的最后一個字符的位置值加上1
//舉個簡單的例子
var a="i am a boy";
var b=a.slice(0,6); //"i am a"
3.splice(數(shù)組)
用法:array.splice(start,deleteCount,item...)
解釋:splice方法從array中移除一個或多個數(shù)組,并用新的item替換它們。參數(shù)start是從數(shù)組array中移除元素的開始位置。參數(shù)deleteCount是要移除的元素的個數(shù)。
如果有額外的參數(shù),那么item會插入到被移除元素的位置上。它返回一個包含被移除元素的數(shù)組。
//舉一個簡單的例子
var a=['a','b','c'];
var b=a.splice(1,1,'e','f'); //a=['a','e','f','c'],b=['b']
4.split(字符串)
用法:string.split(separator,limit)
解釋:split方法把這個string分割成片段來創(chuàng)建一個字符串數(shù)組??蛇x參數(shù)limit可以限制被分割的片段數(shù)量。separator參數(shù)可以是一個字符串或一個正則表達式。如果
separator是一個空字符,會返回一個單字符的數(shù)組。
//再舉一個簡單的例子
var a="0123456";
var b=a.split("",3); //b=["0","1","2"]
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助。