String.prototype.substr() - JavaScript 编辑
The substr()
method returns a portion of the string, starting at the specified index and extending for a given number of characters afterwards.
The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone https://github.com/mdn/interactive-examples and send us a pull request.
The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone https://github.com/mdn/interactive-examples and send us a pull request.Syntax
str.substr(start[, length])
Parameters
start
- The index of the first character to include in the returned substring.
length
- Optional. The number of characters to extract.
Return value
A new string containing the specified part of the given string.
Description
substr()
extracts length
characters from a str
, counting from the start
index.
- If
start
is a positive number, the index starts counting at the start of the string. Its value is capped atstr.length
. - If
start
is a negative number, the index starts counting from the end of the string. Its value is capped at-str.length
. - Note: In Microsoft JScript, negative values of the
start
argument are not considered to refer to the end of the string. - If
length
is omitted,substr()
extracts characters to the end of the string. - If
length
isundefined
,substr()
extracts characters to the end of the string. - If
length
is a negative number, it is treated as0
. - For both
start
andlength
,NaN
is treated as0
.
Polyfill
Microsoft's JScript does not support negative values for the start index. To use this feature in JScript, you can use the following code:
// only run when the substr() function is broken
if ('ab'.substr(-1) != 'b') {
/**
* Get the substring of a string
* @param {integer} start where to start the substring
* @param {integer} length how many characters to return
* @return {string}
*/
String.prototype.substr = function(substr) {
return function(start, length) {
// call the original method
return substr.call(this,
// did we get a negative start, calculate how much it is from the beginning of the string
// adjust the start parameter for negative value
start < 0 ? this.length + start : start,
length)
}
}(String.prototype.substr);
}
Examples
Using substr()
var aString = 'Mozilla';
console.log(aString.substr(0, 1)); // 'M'
console.log(aString.substr(1, 0)); // ''
console.log(aString.substr(-1, 1)); // 'a'
console.log(aString.substr(1, -1)); // ''
console.log(aString.substr(-3)); // 'lla'
console.log(aString.substr(1)); // 'ozilla'
console.log(aString.substr(-20, 2)); // 'Mo'
console.log(aString.substr(20, 2)); // ''
Specifications
Specification |
---|
ECMAScript (ECMA-262) The definition of 'String.prototype.substr' in that specification. |
Browser compatibility
BCD tables only load in the browser
See also
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论