zoukankan      html  css  js  c++  java
  • js中 substr(), substring(), slice()的区别

    一、作用

      三者都是基于原字符串创建新字符串的方法。

      接收一到两个参数,第一个参数截取字符串的开始位置(字符下标,从0开始),第二个参数因方法不同而不同,后面不同点会说到。

      另外,三个方法都不会修改原字符串的值。

    二、相同点

    • 都可以传入一个或两个参数
    • 只传入一个参数时,都表示从指定下标,截取字符串长度,直到字符串最后一个字符
    var str = 'hello sarahshine!';
    
    console.log(str.slice(3));          // 'lo sarahshine!'
    console.log(str.substring(3));      // 'lo sarahshine!'
    console.log(str.subtr(3));          // 'lo sarahshine!'

    三、不同点

    2.1   传入两个参数时,第二个参数代表的意义不同

    • slice ( ) 和 substring ( ) 的第二个参数,都表示截取字符串的结束位置
    • substr ( ) 的第二个参数代表的是,要截取的字符串位数
    var str = 'hello sarahshine!';
    
    console.log(str.slice(3,7));           // 'lo s'
    console.log(str.substring(3,7));       // 'lo s'
    console.log(str.substr(3,7));          // 'lo sara'

    2.2  传入的参数是负数

    • slice ( )  会把所有的负数参数加上字符串的长度值,如:str.slice(-3)   相当于 str.slice(14)
    • substring ( ) 会把所有的负数参数都转为0
    • substr ( ) 会把第一个参数的负值加上字符串的长度值,第二个参数的负值转为0   (毕竟第二个参数是要截取的字符串长度,总不能为负数吧)
    var str = 'hello sarahshine!';  //length = 17
                
    //只传入一个负数
    console.log(str.slice(-3));     // 'ne!'                相当于str.slice(14)
    console.log(str.substring(-3)); // 'hello sarahshine!'  相当于str.substring(0)
    console.log(str.substr(-3));    // 'ne!'                相当于str.substr(14)
                
    //传入两个负数
    console.log(str.slice(-3, -1));     // 'ne'          相当于str.slice(14,16)
    console.log(str.substring(-3, -1)); // ''            相当于str.substring(0,0)
    console.log(str.substr(-3, -1));    // ''            相当于str.substr(14,0)
                
    //传入一正一负
    console.log(str.slice(3, -4));     // 'lo sarahsh'   相当于str.slice(3,13)
    console.log(str.substring(3, -4)); // 'hel'          相当于str.substring(3,0)  即(0,3)
    console.log(str.substr(3, -4));    // ''             相当于str.substr(3,0)

    以上都出自《javascript高级程序设计》 

  • 相关阅读:
    4.2 面向对象分析(二) CRC方法标识概念类
    4.1 面向对象分析(二) 标识概念类和对象
    3.4 面向对象分析(一)面向对象设计(初步)
    3.3 面向对象分析(一)分析模型法
    3.2 面向对象分析(一)名词法
    3.1 面向对象分析与设计概览
    2.7 UML状态图
    2.6 通信图
    2.5 UML顺序图
    2.4 UML类图
  • 原文地址:https://www.cnblogs.com/sarahwang/p/6914590.html
Copyright © 2011-2022 走看看