永鸿传奇 发表于 2023-2-21 18:59:16

JavaScript 中字符串和数组的截取办法总结

字符串

substring

形式:substring(index1, index2)

[*]不会改变原始字符串
[*]将小的参数作为开始位置 start,大的作为结束位置 stop
[*]包含 start,但不包含 stop
[*]如果只给一个参数表示从它 start 截取到字符串结尾
[*]如果某个参数为负,会先将负数变为 0,并以它为 start
var str = "0123456789";
console.log(str.substring(1, 5)); // "1234"
console.log(str.substring(8, 4)); // "4567"
console.log(str.substring(1)); // "123456789"
console.log(str.substring(-2, 6)); // "012345"
console.log(str); // "0123456789"substr

形式:substr(start, length)

[*]不会改变原始字符串
[*]如果缺 length,表示从 start 截取到字符串结尾
[*]如果 start 为负数,那么 start = str.length + start
[*]如果 length 为负数或者 0,那么返回空字符串
var str = "0123456789";
console.log(str.substr(1, 5)); // "12345"
console.log(str.substr(4)); // "456789"
console.log(str.substr(-3)); // "789"
console.log(str.substr(4, 0)); // ""
console.log(str.substr(4, -2)); // ""
console.log(str); // "0123456789"数组

splice

形式:substr(start, length, *args)

[*]会改变原始数组
[*]从指定的索引开始删除若干元素,再从该位置添加若干元素
var arr = ;
console.log(arr.splice(2, 3, 12, 13)); // 返回删除的元素
console.log(arr); //
console.log(arr.splice(2, 3)); //
console.log(arr); //
console.log(arr.splice(2, 0, 22, 23)); // 返回[],没有删除任何元素
console.log(arr); // 数组&字符串

slice

形式:slice(start, stop)

[*]不会改变原始数组/字符串
[*]包含 start,但不包含 stop
[*]如果只给一个参数表示从它 start 截取到字符串结尾
[*]如果 start 比 stop 大(不会互换),或 start 与 stop 相等,则截取为空
[*]如果 start 为负数,那么 start = str.length + start
var str = "0123456789";
var arr = ;
console.log(str.slice(1, 6)); // "12345"
console.log(arr.slice(1, 6)); //
console.log(str.slice(2)); // "23456789"
console.log(arr.slice(2)); //
console.log(str.slice(3,3)); // ""
console.log(arr.slice(3,3)); // []
console.log(str.slice(6,5)); // ""
console.log(arr.slice(6,5)); // []
console.log(str.slice(6,-1)); // "678"参考文章链接

来源:https://www.cnblogs.com/touryung/p/17141284.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!
页: [1]
查看完整版本: JavaScript 中字符串和数组的截取办法总结