首页 > 编程语言 >javascript 提取字符串方法 slice substr substring

javascript 提取字符串方法 slice substr substring

时间:2023-02-09 21:13:26浏览次数:64  
标签:slice indexStart javascript substring length indexEnd str 字符串

本文将对javascript提取字符串的三个方法slice/substr/substring ,进行分析。
这三个方法都具有提取字符串的功能,且都有两个参数。下面将详细介绍三个方法在一些特殊参数值下的行为:

String.prototype.slice(indexStart: number, indexEnd?: number)

  • indexStart >= str.length, 将返回空字符串
  • indexStart < 0, indexStart 将被视为 Math.max(indexStart + str.length, 0);
  • indexStart 被省略、未定义或无法转换为数字(使用 Number(indexStart)),它将被视为 0
  • indexEnd 被省略、未定义或无法转换为数字(使用 Number(indexEnd)),或者如果 indexEnd >= str.lengthslice() 将提取到字符串的末尾。
  • indexEnd < 0, indexEnd 将被视为 Math.max(indexEnd + str.length, 0);
  • 若在转化负值后,indexEnd <= indexStart,将返回空字符串

String.prototype.substr(start: number, length?: number)

  • start > str.length, 将返回空字符串;
  • start < 0, start 将被视为 Math.max(start + str.length, 0);
  • start被省略、未定义,它将被视为 0
  • length被省略、未定义, 或者 start + length >= str.length, substr() 将字符提取到字符串的末尾
  • length < 0, 将返回空字符串
  • startlengthNaN, 它将被视为 0

String.prototype.substring(indexStart: number, indexEnd?: number)

substring()提取字符串不包含indexEnd,但以下情况除外:

  • indexEnd 被省略、未定义, substring()将提取至字符串末尾
  • indexStart === indexEnd, 将返回空字符串
  • indexStart > indexEnd, 那么 substring() 的效果就好像交换了两个参数
  • 小于 0 的参数将被视为 0, 大于 str.length 的参数将被视为 str.length

总结:除非你需要参数交换功能,否则建议使用slice();相比 substrsubstring 也更容易被记住。

通过下面的程序可以输入不同参数来试验各方法的输出
<iframe height="300px" src="https://40n6bm-5173.preview.csb.app/" style="border: none" width="400px"></iframe>

参考文档:

标签:slice,indexStart,javascript,substring,length,indexEnd,str,字符串
From: https://www.cnblogs.com/bldf/p/17106949.html

相关文章

  • JavaScript实现数组对象去重
    有多种实现方式:一、使用Set对象:Array.from(newSet(array))该方法会先创建一个Set对象,然后再使用Array.from方法将Set对象转换为数组,因为Set对象不允许有......
  • JavaScript 入门(下)
    目录​​一、JavaScript简介​​​​二、JavaScript的特点​​​​1、动态改变页面内容​​​​2、动态改变网页的外观​​​​3、验证表单数据​​​​4、响应事件​​​​......
  • JavaScript 入门(上)
    目录​​一、JavaScript简介​​​​二、JavaScript的特点​​​​1、动态改变页面内容​​​​2、动态改变网页的外观​​​​3、验证表单数据​​​​4、响应事件​​​​......
  • 说出下面JavaScript代码运行的结果,说说为什么?
    functiontest(person){person.age=26;person={name:'abc',age:18}returnperson};constp1={name:'xyz',age:19};constp2=test(p1);consol......
  • JavaScript闭包有哪些表现形式?
    在真实的场景中,究竟在哪些地方能体现闭包的存在?1.返回一个函数functionf1(){vara=2;returnfunctionf2(){console.log(a);//2};};varnum=f1();num()......
  • 评测JavaScript代码运行速度的几种方式
    一、使用performance.now()API在JavaScript中,可以使用performance.now()API来评测代码的运行速度。该API返回当前页面的高精度时间戳,您可以在代码执行前后调用......
  • JavaScript插件 图片裁剪photoClip
    阅读目录​​JavaScript插件图片裁剪photoClip​​​​1、截图​​​​2、代码​​​​后台接收并处理图片代码​​JavaScript插件图片裁剪photoClip页面裁剪图片得到bas......
  • JavaScript 常用技巧
    阅读目录对象属性操作对象通过动态属性名称取值根据条件向对象添加属性检查属性是否存在对象中使用动态键进行对象解构扁平化数组值操作空值合并`??`操......
  • JavaScript Array 对象
    阅读目录Array对象什么是数组?创建一个数组访问数组在一个数组中你可以有不同的对象数组方法和属性创建新方法示例数组属性JavaScriptconstructor属......
  • JavaScript 表格小游戏
    阅读目录JavaScript实现表格配对小游戏源码JavaScript实现动态显示表格数据源码源码解析JavaScript实现表格配对小游戏实例描述:当用户点击两个相同......