Home >Web Front-end >JS Tutorial >Detailed explanation of JavaScript string manipulation methods and browser compatibility examples

Detailed explanation of JavaScript string manipulation methods and browser compatibility examples

伊谢尔伦
伊谢尔伦Original
2017-07-25 14:32:211628browse

slice()

Definition: Accepts one or two parameters, the first parameter specifies the starting position of the substring. The second parameter represents the end position of the substring (excluding the character at the end position). If the second parameter is not passed, the length of the string is used as the end position.

1. When the passed parameter is a positive value:


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

2. When the passed parameter is a negative value:


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

3. When the second parameter is smaller than the first parameter:

The second parameter passed in by the slice() method is smaller than the first parameter. If the first parameter is small, an empty string is returned.


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

4. IE compatibility

Under the IE8 browser test, there is no problem and the behavior is consistent with modern browsers .

substring()

Definition: Accepts one or two parameters, the first parameter specifies the starting position of the substring. The second parameter represents the end position of the substring (excluding the character at the end position). If the second parameter is not passed, the length of the string is used as the end position.

1. The passed parameter is a positive value: the same behavior as the slice() method


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

2. The passed parameter is In the case of negative values: The

substring() method will convert all negative parameters to 0. Let’s look at an example:


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

The substring() method will use the smaller number as the starting position and the larger number as the ending position. As in the above example, substring(3,0) and substring(0,3) have the same effect.

4. IE compatibility

Under the IE8 browser test, there is no problem and the behavior is consistent with modern browsers.

substr()

Definition: Accepts one or two parameters, the first parameter specifies the starting position of the substring. The second parameter is somewhat different from the previous method, indicating the number of characters returned. If no second argument is passed, the length of the string is used as the ending position. Let’s look at an example:

1. When the passed parameter is a positive value:


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

2. When the passed parameter is a negative value :

The substr() method will add the negative first parameter to the length of the string, and convert the negative second parameter to 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 compatibility

There will be a problem when the substr() method passes a negative value and the original value will be returned. String. IE9 fixes this issue.

Let me introduce to you the difference between slice, substr and substring

First of all, they both receive two parameters. Slice and substring receive the starting position and the ending position. (excluding the end position), while substr receives the starting position and the length of the string to be returned. Look directly at the following example:


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

Something to note here is: substring uses the smaller of the two parameters as the starting position, the larger parameter as the end position.

For example:


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

Then, when the received parameter is a negative number, slice will compare the length of its string with the corresponding negative number. Add, and the result is used as a parameter; substr just adds the first parameter to the length of the string as the first parameter; substring simply converts all negative parameters directly to 0. The test code is as follows:


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(,-));  //空字符串

Note: IE has an error in handling substr's negative value, and it will return the original string.

The above is the detailed content of Detailed explanation of JavaScript string manipulation methods and browser compatibility examples. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn