网站推广.NET

网站推广.NET

js中函数slice,splice和split有什么区别

来源:互联网

每次遇到这三个值都感觉好懵。每次都很难区分他们。都不知道用那个。终于今天来总结下。

  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"]
slice函数