导航

split splice slice的应用与区分

Posted on 2012-09-11 10:40  jaycie  阅读(718)  评论(1编辑  收藏  举报

这三个在在编程语言中比较难以区分,下面以js为例说明其用法:

1 split:和join相反

  大家知道,join的意思是:连接。没错,join()用于把数组中的所有元素拼接起来放入一个字符串。所带的参数为分割字符串的分隔符,默认是以逗号分开。归属于Array

  split的中文意思是分离,即把字符串分离开,以数组方式存储。归属于Stringstring

Object.split(a,b)这是它的语法
a是必须的决定个从a这分割
b不是必须的,可选。该参数可指定返回的数组的最大长度 。如果设置了该参数,返回的子串不会多于这个参数指定的数组。如果没有设置该参数,整个字符串都会被分割,不考虑它的长度。
注:1、返回的数组中不包括a本身;2、如果把空字符串 ("") 用作 a,那么 stringObject 中的每个字符之间都会被分割。

例:

var str='XHTML、CSS、JavaScript';
var arr=['js','php','asp'];
console.log(arr.join());
console.log(str.split('、',2));

2.splice()

用于插入、删除或替换数组的元素。

语法
arrayObject.splice(index,howmany,element1,.....,elementX)

参数描述:

index 必需。规定从何处添加/删除元素。
该参数是开始插入和(或)删除的数组元素的下标,必须是数字。
howmany 必需。规定应该删除多少元素。必须是数字,但可以是 "0"。
如果未规定此参数,则删除从 index 开始到原数组结尾的所有元素。
element1 可选。规定要添加到数组的新元素。从 index 所指的下标处开始插入。
elementX 可选。可向数组添加若干元素。

返回值 
如果从 arrayObject 中删除了元素,则返回的是含有被删除的元素的数组。

例子: 
<script type="text/javascript">
 var a=[11,22,33];
 b=a.splice(0,1,"x","y",[6,7,8]);
 document.write(b+"<br />");//返回被删除的元素的数组
 a=a.join("|");
 document.write(a);//splice()不能将它的参数展开,concat()可以``
</script>

返回:


x|y|6,7,8|22|33

 

说明
splice() 方法可删除从 index 处开始的零个或多个元素,并且用参数列表中声明的一个或多个值来替换那些被删除的元素。

splice会直接对数组进行修改

例子一:

<script type="text/javascript">
 var a=[99,8,2,6,4,4,6];
 b=a.splice(1,4,"x","y");
 document.write(b+"<br />");
 document.write(a);
</script>
返回
8,2,6,4
99,x,y,4,6

例子二:

<script type="text/javascript">
var a  = [1,2,3];
 a = a.splice(0,2);
 alert(a);  // 输出 1, 2   这里a=[1,2]
 a = a.splice(1,2);
 alert(a);  //  输出 2   这里a=[2]
 a = a.splice(1,2);
 alert(a);  //  没有删除任何数组 , 输出 空 数组
</script>
更好的说明了splice会直接对数组进行修改

注意:和concat() 不同,splice并不将他插入的参数展开。也就是如果插入一个数组,他就是插入数组本身,还不是数组的元素。
而concat()插入数组的话,就会把数组展开,插入数组中的元素,不过当插入的数组里
还有数组的时候,就不会展开了。

3.slice()方法

可从已有的数组中返回选定的元素.

语法
arrayObject.slice(start,end)

start 必需。规定从何处开始选取。如果是负数,那么它规定从数组尾部开始算起的位置。也就是说,-1 指最后一个元素,-2 指倒数第二个元素,以此类推。
end 可选。规定从何处结束选取。该参数是数组片断结束处的数组下标。如果没有指定该参数,那么切分的数组包含从 start 到数组结束的所有元素。如果这个参数是负数,那么它规定的是从数组尾部开始算起的元素。

返回值
返回一个新的数组,包含从 start 到 end (不包括该元素)的 arrayObject 中的元素。

注意不包含end元素!!!!!!!!!!!

该方法并不会修改数组,而是返回一个子数组。

如果想删除数组中的一段元素,应该使用方法 Array.splice()。

例子:

start和end都是数组下标数字,且返回的数组里不包括end
slice不会改变 原来的数组
<script type="text/javascript">
 var a=[99,8,2,6,4,4,6];
 b=a.slice(1,4);
 document.write(b+"<br />");
 document.write(a);
</script>
返回
8,2,6
99,8,2,6,4,4,6

 

深圳本土web前端技术交流群:125776555

欢迎探讨前端最新技术、跳槽经验

深圳web前端