Rumah >hujung hadapan web >tutorial js >js中函数slice,splice和split有什么区别
每次遇到这三个值都感觉好懵。每次都很难区分他们。都不知道用那个。终于今天来总结下。
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"]
Atas ialah kandungan terperinci js中函数slice,splice和split有什么区别. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!