substr与substring的区别

本文涉及的产品
性能测试 PTS,5000VUM额度
应用实时监控服务-可观测链路OpenTelemetry版,每月50GB免费额度
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: substr与substring的区别

一、substr() 方法
语法:substr(start,length)
在字符串中抽取从 start 下标开始的指定数目的字符。
(1)start,提取字符的位置。如果为负值,则被看作 str.Length + start,其中 str.Length 为字符串的长度(例如,如果 start 为 -3,则被看作 strLength + (-3))。
(2)length,可选可不选。选择则输入要提取的字符数,不选就是全部。

var str="Hello world!"
document.write(str.substr(3))
//输出lo world!
//此示例,只有前面提取字符的位置(即start),后面的length则没有填,
//     所以从第3个开始后面的所有都能截取得到

示例二:

var str = "abcdefghij";

console.log(  str.substr(1,2));   //   bc
console.log(  str.substr(-3,2));  //   hi
console.log(  str.substr(-3));    //   hij
console.log(  str.substr(-20,2)); //   ab
console.log(  str.substr(1));     //   bcdefghij
console.log(  str.substr(20,2));  //

二、substring()方法
语法:str.substring(indexStart[, indexEnd])
(1)indexStart为需要截取的第一个字符的索引,该索引位置的字符作为返回的字符串的首字母
(2)indexEnd,可选。一个 0 到字符串长度之间的整数,以该数字为索引的字符不包含在截取的字符串内。
实例:

var str="Hello world!"
document.write(str.substring(3))
//输出为'lo world!'
//因为indexEnd为默认,所以从下标3开始截取,后面的全部截取

示例二:

var str="Hello world!"
         0123456789
document.write(str.substring(3,7))
//indexStart为3,所以从三开始取,取到'l'
//indexEnd为7,所以取到第六位(注意:是第六位),'w'
//所以输出为'lo w'

总计:

从以上示例可以总结出,substr与substring的不同之处是:
substr(a,b),可以从下标为a的位置开始截取,一直截取到包括第b个元素,(取头取尾);
而substring(a,b),是从下标为a的位置开始截取,截取到下标为b-1的位置,(取头取不到尾)。

因此,两种方法的区别在于参数的含义不同。substring方法的第二个参数是结束位置,而substr方法的第二个参数是截取长度。

相关文章
|
6月前
|
Java
substring()方法详解
substring()方法详解
59 1
|
6月前
|
索引
substring()方法
substring()方法
Zp
截取字符串substring与substr之间的区别
截取字符串substring与substr之间的区别
Zp
179 0
|
JavaScript
js substring、substr和slice 截取字符串
js substring、substr和slice 截取字符串
111 0
|
JavaScript
js字符串截取substring和substr
js字符串截取substring和substr
134 0
js字符串截取substring和substr
|
PHP
str_replace() 和 strpos()
str_replace() 和 strpos()
116 0
str_replace() 和 strpos()
|
JavaScript
js中截取字符串的三个方法 substring()、substr()、slice()
js中截取字符串的三个方法 substring()、substr()、slice()
|
关系型数据库 MySQL 数据库
Mysql字符串截取总结:left()、right()、substring()、substring_index()
同步首发:http://www.yuanrengu.com/index.php/20171226.html 在实际的项目开发中有时会有对数据库某字段截取部分的需求,这种场景有时直接通过数据库操作来实现比通过代码实现要更方便快捷些,mysql有很多字符串函数可以用来处理这些需求,如Mysql字符串截取总结:left()、right()、substring()、substring_index()。
2649 0