字符串方法集锦
字符串处理截取slice、substring、substr的异同
在项目开发过中,字符串是一种很特殊的东西,不可逃避地要经常对其处理,截取获得某几个字符是一种经常的事情。然而,在面试题中也经常出现对字符串处理的一些问题,尤其一些大公司,比如:慧*网,最近看其面试题中就有一道:说一下falsh编程中slice()、substring()、substr()的相同点和不同点?
分析该题,其实并不难,但很基础,很多人都用过这三个方法,但都是基于js的,至于falsh编程,由于其as也是基于ECMA262标准的脚本语言,所以没什么不同。
相同点:三个方法都是截取字符串中的子字符串,并返回子字符串,对原字符串不修改。三个方法都可以接收两个参数,第一个参数是子字符串的开始索引,第二个参数则有所区别。如果省略第二个参数则会截取到字符串的结尾。另外三个方法还都可以接收负数的参数,此时则是它们最大的区别之处。
不同点:slice()和substring()接收的第二个参数表示子字符串的结束索引的后面的字符索引,可以理解不包括该索引的子字符串。substr()的第二个参数则表示截取的字符串的长度。
在参数为负数时,slice()则会把参数中无论一个负数还是两个负数,按字符串.length与该负数相加的方式转换为正数,然后再根据正数的方式,从开始索引到结束索引(不包含)的方式截取子字符串,如果转换后的负数还是负数不会继续进行转换。
var str="abcdef";
console.log(str.slice(0));//abcdef
console.log(str.slice(0,3));//abc
console.log(str.slice(-4,3));//c
console.log(str.slice(-3,-1));//截取(6-3, 6-1),得到de
console.log(str.slice(-10,6));//"abcdef",6-10=-4到6,得到abcdef
var str1 = "The morning is upon us.";
console.log(str1.slice(4, -2)); // morning is upon u
var str = "The morning is upon us.";
str.slice(-3); // "us."
str.slice(-3, -1); // "us"
str.slice(0, -1); // "The morning is upon us"
substring()方法在参数为正数时与slice()没有什么区别,唯一的一个特点就是当第二个参数小于第一个参数时,它会把小的参数当作第一个截取的开始索引,大的参数当作结束位置索引(不包含该位置的字符),参数为负数时自动归0。
var str="abcdef";
console.log(str.substring(6,0));//会自动翻转,得到0到6之间的字符abcde
参数是负数时,则把负参数归为0
console.log(str.substring(-100,3));//计算得到0到3之间的字符abc
console.log(str.substring(-1,-9));//0到0之间的字符“”
// assumes a print function is defined
var anyString = "Mozilla";
// Displays "Moz"
console.log(anyString.substring(0,3));
console.log(anyString.substring(3,0));
// Displays "lla"
console.log(anyString.substring(4,7));
console.log(anyString.substring(7,4));
// Displays "Mozill"
console.log(anyString.substring(0,6));
// Displays "Mozilla"
console.log(anyString.substring(0,7));
console.log(anyString.substring(0,10));
substr()方法在参数为负数时,第一个参数如果为负数,则按字符串.length+第一个参数的方式转换为正数,如果第二个参数为负数则归为0。
var str="abcdef";
console.log(str.substr(-6,-100));//从0开始截取0个字符得到“”
console.log(str.substr(-6));//从0开始到结束得到abcdef
var str = "abcdefghij";
console.log("(1): " + str.substr(1)); // (1): bcdefghij
console.log("(1,2): " + str.substr(1,2)); // (1,2): bc
console.log("(-3): " + str.substr(-3)); // (-3): hij
console.log("(-3,2): " + str.substr(-3,2)); // (-3,2): hi
console.log("(20, 2): " + str.substr(20,2)); // (20, 2):
console.log("(-20, 2): " + str.substr(-20,2)); // (-20, 2): ab
// ie8及以下
console.log("(-3): " + str.substr(-2)); // (-20, 2): hij
console.log("(-3, 2): " + str.substr(-2)); // (-20, 2): ab
至此三个方法的异同点总结完毕。