字符串方法之String.slice()与String.substring()

String.slice(start, end) 和 String.substring(start, end) 是 JavaScript/TypeScript 中字符串对象的两种常见方法,用于提取子字符串。

String.slice(start, end)

用法:

  slice 方法返回从 start 索引位置开始,到 end 索引位置之前的子字符串。

  示例代码:


const str = 'Hello, World!';

console.log(str.slice(7));      // 输出: "World!"
console.log(str.slice(7, 12));  // 输出: "World"
console.log(str.slice(-6));     // 输出: "World!"
console.log(str.slice(7, -1));  // 输出: "World"

  在上述示例中,slice 方法根据提供的参数从字符串中提取了不同的子字符串。

注意点:

  • start 参数可选,表示起始索引位置,默认为 0。如果为负数,则表示从字符串末尾的索引位置开始计算。
  • end 参数可选,表示结束索引位置,默认为字符串的长度。如果为负数,则表示从字符串末尾的索引位置开始计算。
  • 返回的子字符串包括 start 索引位置的字符,但不包括 end 索引位置的字符。(包左不包右)
  • 如果 start 大于等于 end,则返回一个空字符串
  • 原始字符串不会被修改

String.substring(start, end)

用法:

  substring 方法返回从 start 索引位置开始,到 end 索引位置之前的子字符串。
  示例代码:


const str = 'Hello, World!';

console.log(str.substring(7));      // 输出: "World!"
console.log(str.substring(7, 12));  // 输出: "World"
console.log(str.substring(-6));     // 输出: "Hello, World!"
console.log(str.substring(7, -1));  // 输出: "Hello, World"

  在上述示例中,substring 方法根据提供的参数从字符串中提取了不同的子字符串。

注意点:

  • start 参数必需,表示起始索引位置。如果为负数或大于 end,则会交换 start 和 end 的值
  • end 参数可选,表示结束索引位置,默认为字符串的长度。如果为负数,则被视为 0。
  • 返回的子字符串包括 start 索引位置的字符,但不包括 end 索引位置的字符。(包左不包右)
  • 如果 start 和 end 相等,或 start 大于 end,则返回一个空字符串
  • 原始字符串不会被修改

区别

处理负数参数:

  slice 方法接受负数作为参数,而 substring 方法不接受负数。如果 slice 方法的参数为负数,它会从字符串的末尾开始计算索引位置。例如,str.slice(-6) 会返回从倒数第六个字符开始到字符串末尾的子字符串。

参数交换行为:

  当 start 大于 end 时,slice 方法会返回一个空字符串,而 substring 方法会自动交换 start 和 end 的值。例如,str.slice(7, 2) 返回空字符串,而 str.substring(7, 2) 实际上会交换参数并返回 str.substring(2, 7) 所返回的子字符串。

对原始字符串的影响:

  slice 和 substring 方法都不会修改原始字符串。它们返回的是提取的子字符串,而不会影响原始字符串的内容。

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小新-alive

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值