深入浅析JavaScript字符串操作方法 slice、substr、substring及其IE兼容性


Posted in Javascript onDecember 16, 2015

在截取字符串时常常会用到substr()、substring()、slice()方法,有时混淆之间的用法,故总结下。

阅读目录
•slice()
•substring()
•substr()
•总结 

slice()

定义:接受一个或者两个参数,第一个参数指定子字符串的开始位置。第二个参数表示子字符串的结束位置(不包括结束位置的那个字符),如果没有传递第二个参数,则将字符串的长度作为结束位置。

1、传递参数为正值情况:

var str ="helloWorld";
// 一个参数,则将字符串长度作为结束位置
alert(str.slice(3)); // "loWorld"
// 两个参数,7位置上的字符为"r",但不包括结束位置的字符
alert(str.slice(3,7)); // "loWo"

2、传递参数为负值的情况:

slice()方法会将传入的负值与字符串长度相加。
 var str ="helloWorld";
// 一个参数,与字符串长度相加即为slice(7)
alert(str.slice(-3)); // "rld"
// 两个参数,与字符串长度相加即为slice(3,6)
alert(str.slice(3,-4)); // "loW"

3、第二个参数比第一个参数值小的情况:

slice()方法传入的第二个参数比第一个参数小的话,则返回空字符串。

var str ="helloWorld";
alert(str.slice(5,3)); // ""

4、IE兼容性

在IE8浏览器测试下,没啥问题,行为与现代浏览器一致。

substring()

定义:接受一个或者两个参数,第一个参数指定子字符串的开始位置。第二个参数表示子字符串的结束位置(不包括结束位置的那个字符),如果没有传递第二个参数,则将字符串的长度作为结束位置。

1、传递参数为正值情况:与slice()方法行为相同的

var str ="helloWorld";
// 一个参数,则将字符串长度作为结束位置
alert(str.substring(3)); // "loWorld"
// 两个参数,7位置上的字符为"r",但不包括结束位置的字符
alert(str.substring(3,7)); // "loWo"

2、传递参数为负值的情况:

substring()方法会把所有负值参数转换为0。来看下例子:

var str ="helloWorld";
// 两个参数,-4会转换为0,相当于substring(3,0) -->即为 substring(0,3)
alert(str.substring(3,-4)); // "hel"

substring()方法会将较小的数作为开始位置,将较大的数作为结束位置。如上面的例子substring(3,0) 与substring(0,3)是一样效果的。

4、IE兼容性

在IE8浏览器测试下,没啥问题,行为与现代浏览器一致。

substr()

定义:接受一个或者两个参数,第一个参数指定子字符串的开始位置。第二个参数跟之前的方法有些区别,表示返回的字符个数。如果没有传递第二个参数,则将字符串的长度作为结束位置。来看例子:

1、传递参数为正值情况:

var str ="helloWorld";
// 一个参数,则将字符串长度作为结束位置
alert(str.substr(3)); // "loWorld"
// 两个参数,从位置3开始截取后面7个字符
alert(str.substr(3,7)); // "loWorld"

2、传递参数为负值的情况:

substr()方法会将负的第一个参数加上字符串的长度,而将负的第二个参数转换为0。

var str ="helloWorld";
// 将第一个负的参数加上字符串的长度--->
//即为:substr(7,5) ,从位置7开始向后截取5个字符
alert(str.substr(-3,5)); // "rld"
// 将第二个参数转换为0
// 即为:substr(3,0),即从位置3截取0个字符串,则返回空
alert(str.substr(3,-2)); // ""

3、IE兼容性

substr()方法传递负值的情况下会存在问题,会返回原始的字符串。IE9修复了此问题。

总结

在传递正值参数情况下,slice() 和 substring () 行为是一致的,substr()方法在第二个参数上会容易混淆

在传递负值参数情况下,slice() 方法是通过字符串长度相加,符合一般思维,substring()第二个参数转换为0会容易出问题,起始位置会容易变更,substr() 方法负值情况下会出现IE兼容性问题。

综上,小弟一般推荐使用slice()方法。

下面给大家介绍slice,substr和substring的区别

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

var test = 'hello world';
  alert(test.slice(,));    //o w
  alert(test.substring(,));   //o w
  alert(test.substr(,));   //o world

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

如:

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

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

var test = 'hello world';  
alert(test.slice(-));   //rld  
alert(test.substring(-));  //hello world  
alert(test.substr(-));  //rld  
alert(test.slice(,-));  //lo w  
alert(test.substring(,-)); //hel  
alert(test.substr(,-));  //空字符串

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

Javascript 相关文章推荐
JavaScript高级程序设计(第3版)学习笔记12 js正则表达式
Oct 11 Javascript
Node.js实现在目录中查找某个字符串及所在文件
Sep 03 Javascript
jquery+php实现搜索框自动提示
Nov 28 Javascript
JavaScript jquery及AJAX小结
Jan 24 Javascript
bootstrap输入框组代码分享
Jun 07 Javascript
JavaScript判断数组是否存在key的简单实例
Aug 03 Javascript
基于JS实现checkbox全选功能实例代码
Oct 31 Javascript
教你用十行node.js代码读取docx的文本
Mar 08 Javascript
Vue.js实现文章评论和回复评论功能
May 30 Javascript
微信小程序左右滚动公告栏效果代码实例
Sep 16 Javascript
layui switch 开关监听 弹出确定状态转换的例子
Sep 21 Javascript
基于postman获取动态数据过程详解
Sep 08 Javascript
js如何判断输入字符串长度
Dec 16 #Javascript
常常会用到的截取字符串substr()、substring()、slice()方法详解
Dec 16 #Javascript
jQuery添加和删除指定标签的方法
Dec 16 #Javascript
详解JavaScript基于面向对象之继承实例
Dec 16 #Javascript
javascript实现拖放效果
Dec 16 #Javascript
js判断手机访问或者PC的几个例子(常用于手机跳转)
Dec 15 #Javascript
Jquery插件easyUi实现表单验证示例
Dec 15 #Javascript
You might like
一个不易被发现的PHP后门代码解析
2014/07/05 PHP
浅谈php+phpStorm+xdebug配置方法
2015/09/17 PHP
全面解读PHP的人气开发框架Laravel
2015/10/15 PHP
WordPress中重置文章循环的rewind_posts()函数讲解
2016/01/11 PHP
PHP简单实现正则匹配省市区的方法
2018/04/13 PHP
Laravel框架实现简单的学生信息管理平台案例
2019/05/07 PHP
PHP7移除的扩展和SAPI
2021/03/09 PHP
来自qq的javascript面试题
2010/07/24 Javascript
自己写的Javascript计算时间差函数
2013/10/28 Javascript
JavaScript charCodeAt方法入门实例(用于取得指定位置字符的Unicode编码)
2014/10/17 Javascript
jQuery 实现侧边浮动导航菜单效果
2014/12/26 Javascript
JS特效实现图片自动播放并可控的效果
2015/07/31 Javascript
详解微信小程序开发—你期待的分享功能来了,微信小程序序新增5大功能
2016/12/23 Javascript
12306 刷票脚本及稳固刷票脚本(防挂)
2017/01/04 Javascript
浅谈jQuery框架Ajax常用选项
2017/07/08 jQuery
详解JavaScript函数callee、call、apply的区别
2019/03/08 Javascript
layui 表格操作列按钮动态显示的实现方法
2019/09/06 Javascript
nodejs中使用archive压缩文件的实现代码
2019/11/26 NodeJs
node.js Promise对象的使用方法实例分析
2019/12/26 Javascript
Python 检查数组元素是否存在类似PHP isset()方法
2014/10/14 Python
Python基础教程之正则表达式基本语法以及re模块
2016/03/25 Python
python3.6.3+opencv3.3.0实现动态人脸捕获
2018/05/25 Python
利用python对Excel中的特定数据提取并写入新表的方法
2018/06/14 Python
python实现三维拟合的方法
2018/12/29 Python
python 公共方法汇总解析
2019/09/16 Python
Python从列表推导到zip()函数的5种技巧总结
2019/10/23 Python
基于Python检测动态物体颜色过程解析
2019/12/04 Python
HTML5之SVG 2D入门13—svg对决canvas及长处和适用场景分析
2013/01/30 HTML / CSS
可爱的童装和鞋子:Fabkids
2019/08/16 全球购物
春风行动实施方案
2014/03/28 职场文书
高校优秀辅导员事迹材料
2014/05/07 职场文书
师范毕业生求职信
2014/07/11 职场文书
2015年教师自我评价范文
2015/03/04 职场文书
责任书范本大全
2015/05/11 职场文书
学校食堂管理制度
2015/08/04 职场文书
浅谈Python类的单继承相关知识
2021/05/12 Python