slice,substr和substring的区别

Posted codeing or artist ?

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了slice,substr和substring的区别相关的知识,希望对你有一定的参考价值。

首先,他们都接收两个参数,slice和substring接收的是起始位置和结束位置(不包括结束位置),而substr接收的则是起始位置和所要返回的字符串长度。直接看下面例子:

 

var test = ‘hello world‘;

alert(test.slice(4,7));             //o w
alert(test.substring(4,7));         //o w
alert(test.substr(4,7));            //o world

 

这里有个需要注意的地方就是:substring是以两个参数中较小一个作为起始位置,较大的参数作为结束位置。

如:

 

alert(test.substring(7,4));          //o w

 

接着,当接收的参数是负数时,slice会将它字符串的长度与对应的负数相加,结果作为参数;substr则仅仅是将第一个参数与字符串长度相加后的结果作为第一个参数;substring则干脆将负参数都直接转换为0。测试代码如下:

 

var test = ‘hello world‘;

alert(test.slice(-3));         //rld
alert(test.substring(-3));     //hello world
alert(test.substr(-3));        //rld

alert(test.slice(3,-4));       //lo w
alert(test.substring(3,-4));   //hel
alert(test.substr(3,-4)      //空字符串

注意:IE对substr接收负值的处理有错,它会返回原始字符串。

 

以上是关于slice,substr和substring的区别的主要内容,如果未能解决你的问题,请参考以下文章

substring,substr,和slice的区别详解

substring,substr,和slice的区别详解。

substr和substring的区别

slice()substring()和substr()的作用和区别

javascript中slice和substring的区别

JS 中substring() , substr(), slice() 的区别