欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  web前端

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

程序员文章站 2022-06-03 16:02:36
...
每次遇到这三个值都感觉好懵。每次都很难区分他们。都不知道用那个。终于今天来总结下。
  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(' ')或者使用正则表达式作为 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有什么区别的详细内容,更多请关注其它相关文章!