12.javascript 字符串方法

1.获取字符串长度str.length

var txt = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
var sln = txt.length;

2.判断一个字符串中是否存在某字符串str.indexof("要匹配的字符串");

  有存在:返回字符串首次出现的索引位置

  不存在:返回-1

var str = "The full name of China is the People's Republic of China.";
var pos = str.indexOf("China");
document.getElementById("demo").innerHTML = pos;
//结果是17

2.查找某个文本在字符串中最后一次出现的索引位置str.lastIndexOf("需要查找的字符串");

  有存在:返回指定文本在字符串中最后一次出现的索引位置

  没找到:返回-1

var str = "The full name of China is the People's Republic of China.";
var pos = str.lastIndexOf("China");
document.getElementById("demo").innerHTML = pos;
//结果51

3.indexof()和lastIndexOf()都接收第二个参数

  str.indexof("要查找的字符串",18);这个18表示从18的索引位置开始搜索到结尾。

  str.lastIndexOf("要匹配的字符串",50);这个50表示从索引位置50开始检索,直到字符串的起点。

4.查找字符串中是否有某字符串.search("要查找的字符串");,返回第一次出现的索引位置,跟indexof()有点类似,没有找到也是返回-1

var str = "The full name of China is the People's Republic of China.";
var pos = str.search("China");
document.getElementById("demo").innerHTML = pos;
//结果是17

indexof()与search()区别:

  search()方法无法设置第二个开始位置参数

  indexof()方法无法设置更强大的搜索值,比如正则表达式  

5.提取部分字符串str.slice(start,end);

  提取字符串的某个部分并在新字符串返回被提取的部分,第二个参数省略的话,默认提取到结尾

var str = "Apple, Banana, Mango";
var res = str.slice(7,13);
//结果是:Banana
var str = "Apple, Banana, Mango";
var res = str.slice(-13,-7);
//结果:Banana
var str = "Apple, Banana, Mango";
var res = str.slice(7);
document.getElementById("demo").innerHTML = res;
//结果:Banana Mango
var str = "Apple, Banana, Mango";
var res = str.slice(-13) 
document.getElementById("demo").innerHTML = res;
//结果:Banana Mango

6.提取部分字符串str.substring(start,end);  

  类似于str.slice(start,end),不同之处在于substring()无法接收负数索引。也可省略第二个参数,默认截取到末尾。

7.提取部分字符串str.substr(start,length);

  类似于str.slice(start,end),不同之处是substr()第二个参数是截取长度。也可省略第二个参数,默认截取到末尾。

var str = "Apple, Banana, Mango";
var res = str.substr(7,6);
//结果是:Banana

8.替换字符串的内容str.replace("原字符串","新字符串");

  用另外一个值替换在字符串中指定的值。大小写敏感,只替换第一次出现的位置。

str = "Please visit Microsoft and Microsoft!";
var n = str.replace("Microsoft", "W3School");

  如果执行大小写不敏感的替换,使用正则表达式/i(大小写不敏感),正则表达式是不带引号的

str = "Please visit Microsoft!";
var n = str.replace(/MICROSOFT/i, "W3School");

  替换所有出现的次数,匹配的字符串,使用正则表达式/g标志,用于全局搜索

str = "Please visit Microsoft and Microsoft!";
var n = str.replace(/Microsoft/g, "W3School");

9.将字符串转大写str.toUpperCase();

var text1 = "Hello World!";       // 字符串
var text2 = text1.toUpperCase();  // text2 是被转换为大写的 text1

10.将字符串转小写str.toLowerCase();

var text1 = "Hello World!";       // 字符串
var text2 = text1.toLowerCase();  // text2 是被转换为小写的 text1

11.拼接字符串str.concat("需要添加的字符串","我可以有多个","反正从左往右一直拼接在一起"),有点像:“字符串A” + "字符串B"

var text1 = "Hello";
var text2 = "World!";
var text3 = text1.concat("来拼接呀",text2);
document.getElementById("demo").innerHTML = text3;
//结果:Hello来拼接呀World!

12.字符串去除左右空格,删除字符串两端的空白符str.trim();

var str = "       Hello World!        ";
alert(str.trim());

13.提取字符串指定位置的字符charAt(position);

  返回字符串中指定下标位置的字符

var str = "HELLO WORLD";
str.charAt(0);            // 返回 H

14.提取字符串指定位置字符的Unicode编码

var str = "HELLO WORLD";
str.charCodeAt(0);         // 返回 72

15.还有通过属性的方式访问字符,了解就行,最好别用

  它让读者看起来像数组,其实并不是

  如果找不到字符,[ ]返回undefined,而charAt()返回空字符串

  它是只读的,str[0]="A";不会产生错误,但是也不会工作

var str = "HELLO WORLD";
str[0];                   // 返回 H
var str = "HELLO WORLD";
str[0] = "A";             // 不产生错误,但不会工作
str[0];                   // 返回 H

16.把一个字符串分割成字符串数组str.split();

  下面的n已经是数组了,不在是字符串

var str="How are you doing today?";
var n=str.split();
//结果:How are you doing today?

  分割每个字符,包括空格

var str="How are you doing today?";
var n=str.split("");
//结果:H,o,w, ,a,r,e, ,y,o,u, ,d,o,i,n,g, ,t,o,d,a,y,?

  使用 limit 参数,n 将输出3个数组的值

var str="How are you doing today?";
var n=str.split(" ",3);
//结果:How,are,you

  使用一个字符作为分隔符

var str="How are you doing today?";
var n=str.split("o");
//结果:H,w are y,u d,ing t,day?

 

posted @ 2022-01-05 23:29  种太阳  阅读(59)  评论(0编辑  收藏  举报