liyinSakura


稻花香里说丰年,听取人生经验。


js截取字符串方法整理

昨天客服跟我说某项目分公司官网又出问题了。我说我这边看着没事啊。后来拿火狐浏览器测试也没有问题,结果拿上ie测试终于发现是有问题的。经过今天F12排查发现是字符串截取出了问题。由于需求截取了一下后台传过来的分公司名字,开始使用了:title.substr(3,)。谷歌浏览器看着没问题就直接提交了。结果ie认为是语法错误。后来想想好像这个substr不是js的截取是php的截取,度娘了一下换成:title.slice(3)终于在ie上也没问题了。所以想整理一下js截取字符的方法,虽然这个好像度娘上已经一堆了[X


刚刚发现其实substr也是可以的,开始报语法错误是因为“,”没有去掉、


正题

1
2
3
4
5
6
7
var str = '123456';
console.log(str.substring(3));//456
console.log(str.substr(3));//456
console.log(str.slice(3));//456
console.log(str[3]);//4
console.log(str[8]);//undefined
console.log(str.substring(0, 2));//12

文档上的说明:


arrayObject.slice(start,end)
start必需。规定从何处开始选取。如果是负数,那么它规定从数组尾部开始算起的位置。也就是说,-1 指最后一个元素,-2 指倒数第二个元素,以此类推。
end可选。规定从何处结束选取。该参数是数组片断结束处的数组下标。如果没有指定该参数,那么切分的数组包含从 start 到数组结束的所有元素。如果这个参数是负数,那么它规定的是从数组尾部开始算起的元素。


stringObject.substring(start,end)
start必需。一个非负的整数,规定要提取的子串的第一个字符在 stringObject 中的位置。
stop可选。一个非负的整数,比要提取的子串的最后一个字符在 stringObject 中的位置多 1。
如果省略该参数,那么返回的子串会一直到字符串的结尾。
与 slice() 和 substr() 方法不同的是,substring() 不接受负的参数。


stringObject.substr(start,length)
start必需。要抽取的子串的起始下标。必须是数值。如果是负数,那么该参数声明从字符串的尾部开始算起的位置。也就是说,-1 指字符串中最后一个字符,-2 指倒数第二个字符,以此类推。
length可选。子串中的字符数。必须是数值。如果省略了该参数,那么返回从 stringObject 的开始位置到结尾的字串.

ECMAscript 没有对该方法进行标准化,因此反对使用它。


总结:还是用slice和substring吧。