JS数组的slice()方法传负数和字符串操作函数中的slice()、substr()、substring()

本文详细解析了JavaScript中slice()方法的使用,包括其定义、语法、参数解释及返回值说明。通过实例展示了如何利用slice()从数组或字符串中选取特定元素,对比了slice()与其他字符串方法的区别。
摘要由CSDN通过智能技术生成

 

定义和用法

slice() 方法可从已有的数组中返回选定的元素。

语法

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

返回值

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

说明

请注意,该方法并不会修改数组,而是返回一个子数组。如果想删除数组中的一段元素,应该使用方法 Array.splice()。

提示和注释

注释:您可使用负值从数组的尾部选取元素。

注释:如果 end 未被规定,那么 slice() 方法会选取从 start 到数组结尾的所有元素。

注意,当有两个系数的时候只有算start而不算end位置的数

 

示例:

当只有x时:

1 、x为正数时: 
三种方法得到的结果相同

var c1="123456789"
var c2=c1.slice(4);
var c3=c1.substr(4);
var c4=c1.substring(4);
alert(c2);//"56789"
alert(c3);//"56789"
alert(c4);//"56789"

 

2、x为负数时: 
slice()与sbustr()会将负的参数加上字符串的长度

var c1="123456789"
var c2=c1.slice(-4);//相当于c1.slice(9+(-4))
var c3=c1.substr(-4);//相当于c1.slice(9+(-4))
alert(c2);//"6789"
alert(c3);//"6789"

 

3.

substring()会将负的参数转换为0

var c4=c1.substring(-4);
alert(c4);//"123456789"

当有两个参数时
slice()方法在第一个参数为负数时不管第二个参数为正数还是负数都会返回”“;第二个参数为负数时会将负的参数加上字符串的长度。

var c1="123456789";
var c2=c1.slice(-2,3);//""
var c3=c1.slice(-2,-3);//""
var c4=c1.slice(2,-3);//"3456"



substring()方法会将参数中的负数转换为0,不管这个负数是第几个;注意,这个方法总会将较小的数作为起始,较大的数作为结束。

var c1="123456789";
var c2=c1.substring(2,-3);//"12"
var c3=c1.substring(-2,3);//"123"
var c4=c1.substring(-2,-3);//""
var c5=c1.substring(-3,5);//"789"



substr()方法:如果第二个参数时负数的话会将其转换为0,而第二个参数代表的是选取的个数,所以会返回”“; 
第一个参数为正就从左往右,0代表字符串中的第一个,1代表第二个……-1代表从右往左数第一个,-2代表从右往左数第二个……

var c1="123456789";
var c2=c1.substr(2,-3);//""
var c3=c1.substr(-4,3);//"678"
var c4=c1.substr(-2,-3);//""



数组中的slice()方法,它的结果和字符串中的一样。

var c1=["1","2","3","4","5","6","7","8","9"]
var c2=c1.slice(-2,3);//[]
var c3=c1.slice(-2,-3);//[]
var c4=c1.slice(2,-3);//["3","4","5","6"]

参考自:https://blog.csdn.net/qq_16844491/article/details/78486636

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值