首页 > 其他分享 >JS中字符串28种常用API总结,substring、slice、JSON.stringify、match、split、search、indexOf......

JS中字符串28种常用API总结,substring、slice、JSON.stringify、match、split、search、indexOf......

时间:2023-06-28 10:56:02浏览次数:49  
标签:search slice console log indexOf str2 str 字符串 const

一、引言

在前端开发中,处理字符串是一项常见的任务。JavaScript 提供了一系列的字符串 API,用于操作和处理字符串数据。字符串常用的API方法有很多,包括查找字符串、截取字符串、替换字符串、分割字符串、大小写转换、字符串拼接和字符串比较等等。本文将介绍一些常用的字符串 API,并提供相应的代码示例。

二、substring()方法和slice()方法

1.substring()方法

字符串的截取可以使用substring()方法和slice()方法。其中substring()方法接受两个参数,第一个参数是起始位置,第二个参数是结束位置,截取的字符串不包括结束位置的字符。

let str = "Hello, World!";
let str2 = "卡布奇诺,拿铁,维也纳,摩卡,冰美式,库比卡,浓缩"
console.log(str.substring(1, 8));    //ello, W
console.log(str2.substring(5, 8));  //拿铁,
console.log(str2);  //卡布奇诺,拿铁,维也纳,摩卡,冰美式,库比卡,浓缩
//substring(1, 8) 返回从下标1开始8结束(不包括8)的长度为7的子字符串。

2.slice()方法

slice()方法也接受两个参数,第一个参数是起始位置,第二个参数是结束位置,但是可以使用负数表示从后往前数的位置。返回一个新字符串,不会影响原始字符串。如果省略第二个参数,该方法会提取字符串的剩余部分。提取的字符串为[start, end)长度的子字符串,其中起始位置包含第一个字符。

let str = "123456789";
console.log(str.slice(0, 5));   //12345
console.log(str.slice(2));      //3456789
console.log(str.slice(3, -2));  //4567
console.log(str);     //123456789
let str2 = "给我来一杯卡布奇诺!";
console.log(str2.slice(0, 5));  //给我来一杯
console.log(str2.slice(2));     //来一杯卡布奇诺!
console.log(str2.slice(3, -2)); //一杯卡布奇
console.log(str2.slice(3, -4)); //一杯卡
console.log(str2);    //给我来一杯卡布奇诺!

三、replace()方法和replaceAll()方法

1.replace()方法

replace() 方法用于将指定的字符串或正则表达式匹配的部分替换为新的字符串,替换字符串中的第一个匹配项。

const str = "Hello, World! World!";
const newStr = str.replace("World", "JavaScript");
console.log(newStr);  //Hello, JavaScript! World!

//将一个或多个空格替换成空字符
const str2 = "你    好 呀!"
const newStr2 = str2.replace(/\s+/g, "");
console.log(newStr2);  //你好呀!

replace("World", "JavaScript") 将字符串中的第一个 "World" 替换为 "JavaScript"。

正则表达式 /\s+/g 可以匹配所有连续的空格字符。其中,\s 表示空白字符,包括空格、制表符和换行符,+ 表示匹配一个或多个。

2.replaceAll()方法

replaceAll() 方法是在 ES2021(ES12)中引入的,用于替换字符串中所有匹配的部分。

const str3 = "哎哟! 你干嘛啊啊啊!";
const newStr3 = str3.replaceAll("啊", "呀");
console.log(newStr3);  //哎哟! 你干嘛呀呀呀!
const str4 = "你    好 呀!"
const newStr4 = str4.replaceAll(" ", "");
console.log(newStr4);  //你好呀!

可以直接将字符串空格作为第一个参数,将空字符串作为第二个参数,这样可以把所有的空格字符替换为空字符。

四、trim()方法

trim() 方法去除字符串两端的空格,返回新的字符串。

let str = "    卡布奇诺 拿铁 维也纳    摩卡 冰美式 浓缩  "
console.log(str.trim());        //卡布奇诺 拿铁 维也纳    摩卡 冰美式 浓缩
console.log(str.trimStart()); //卡布奇诺 拿铁 维也纳    摩卡 冰美式 浓缩    
console.log(str.trimEnd());   //    卡布奇诺 拿铁 维也纳    摩卡 冰美式 浓缩

trim()去掉了字符串开头和结尾的空格。trimStart()(trimLeft) 只删除字符串开头的空格,trimEnd()(trimRight) 只删除字符串结尾的空格。trimLeft()和trimRight()方法现已舍弃。

五、match()方法

match方法用于在一个字符串中查找匹配的子串,并返回一个数组,包含所有匹配的子串及其位置。

语法: string.match(regexp),其中,string是要匹配的字符串,regexp是一个正则表达式。

如果regexp没有全局标志g,则match()方法返回一个数组,该数组的第一个元素是匹配到的子串,后面的元素是正则表达式中的捕获组(如果有的话)。

如果regexp有全局标志g,则match()方法返回所有匹配到的子串组成的数组。如果没有匹配到任何子串,则返回null。

const str = "Hello, World!";
const matches = str.match(/l/g);
console.log(matches);  //[ 'l', 'l', 'l' ]

//使用"/(l)(o)/g"正则表达式来查找字符串中所有的 "lo" 组合。
const str2 = "Hello, World!";
const matches2 = str2.match(/(l)(o)/g);
console.log(matches2);  //[ 'lo' ]

//使用"/o/g"正则表达式来查找字符串中所有的小写字母 "o"。
const str3 = 'Hello, World!';
console.log(str3.match('o'));//['o', index: 4, input: 'Hello, World!', groups: undefined]
console.log(str3.match('l'));//['l', index: 2, input: 'Hello, World!', groups: undefined]
console.log(str3.match(/o/g)); //['o', 'o']

六、split()方法

split() 方法将字符串按指定的分隔符拆分成数组。

//s.split("-")使用-作为分隔符将字符串拆分成数组。
const s = "卡布奇诺-拿铁-维也纳-摩卡-冰美式-浓缩";
const arr = s.split("-");
console.log(arr); //[ '卡布奇诺', '拿铁', '维也纳', '摩卡', '冰美式', '浓缩' ]

const str = "Hello     World!";
console.log(str.split(/\s+/));   //['Hello', 'World!']
const str2 = "Hello,World!";
console.log(str2.split("-"));     //['Hello,World!']

/\s+/正则表达式匹配一个或多个空白字符。如果分隔符没有在字符串中出现,split函数会返回一个包含整个字符串作为唯一元素的数组。

七、search()方法

search方法用于在一个字符串中查找匹配的子串,并返回第一个匹配的子串的位置。它可以接受一个参数,用于指定要查找的子串。

const str = "Hello, World!";
console.log(str.search(/World/i));  //7
console.log(str.search(/world/i));  //7
console.log(str.search("World"));  //7
console.log(str.search("l"));  //2
const str2 = "维也纳,拿铁,摩卡,冰美式,浓缩";
console.log(str2.search("拿铁"));      //4
console.log(str2.search("卡布奇诺")); //-1

/World/i 是一个正则表达式,用于匹配字符串中的 "World",其中 i 是忽略大小写的标志。 如果找不到匹配的子串则返回-1。

八、valueOf()方法

valueOf()方法返回字符串对象的原始值

const num = 123;
const str = "卡布奇诺 拿铁 维也纳 摩卡 冰美式";
const bool = true;
const obj = {name:"咖啡", type:"卡布奇诺"}
const arr = ["拿铁", "摩卡", "美式", "卡布奇诺"]
const date = new Date();

console.log(num.valueOf());   //123
console.log(str.valueOf());     //"卡布奇诺 拿铁 维也纳 摩卡 冰美式"
console.log(bool.valueOf());  //true
console.log(obj.valueOf());   //{name: '咖啡', type: '卡布奇诺'}
console.log(arr.valueOf());    //['拿铁', '摩卡', '美式', '卡布奇诺']
console.log(date.valueOf());  //1685850114551  (获取时间戳)

valueOf()方法返回一个对象的原始值。如果对象本身就是一个原始值(如数字、字符串、布尔值),则直接返回该值;否则,返回对象本身。

九、concat()方法

concat用于将多个字符串连接成一个新的字符串。该方法不会改变原有的字符串,而是返回一个新的字符串。

语法:string.concat(str1, str2, ..., strN)

其中,string是要连接的字符串,str1, str2, ..., strN是要连接的其他字符串,可以有多个参数。

const str1 = "冰美式";
const str2 = "和摩卡";
const str3 = "!";
const result = str1.concat(str2, str3);
console.log(result);  //冰美式和摩卡!
console.log(str1);    //冰美式
console.log(str2);    //和摩卡
console.log(str3);    //!

concat()方法返回的是一个新的字符串,原有的字符串不会改变。如果要改变原有的字符串,可以使用赋值运算符(+=)或字符串模板(用 `` 和 ${} )来实现。

 
let str = "冰美式";
str += "和摩卡!";
console.log(str);   //冰美式和摩卡!

let str2 = "冰美式";
str2 = `${str2}和摩卡!`;
console.log(str2);  //冰美式和摩卡!

十、JSON.stringify()方法

JSON.stringify()是JavaScript中的一个方法,用于将JavaScript对象转换为JSON字符串。该方法接受一个JavaScript对象作为参数,并返回一个JSON字符串。

语法:JSON.stringify(value, replace, space)

  1. value是要转换为JSON字符串的JavaScript对象;
  2. replace是一个函数,用于控制转换过程中哪些属性应该被包含在JSON字符串中;
  3. space是一个用于缩进输出的空格数或缩进字符串。
const person = {
  name: "张三",
  age: 20,
  city: "南昌",
  fn: function(){console.log(666);},
  test: undefined,
  hobbies: ["读书", "旅游", "羽毛球"]
};
console.log(JSON.stringify(person));
//{"name":"张三","age":20,"city":"南昌","hobbies":["读书","旅游","羽毛球"]}
console.log(JSON.stringify(person, ["name", "hobbies"]));
//{"name":"张三","hobbies":["读书","旅游","羽毛球"]}
console.log(JSON.stringify(person, null, 2));
// {
//   "name": "张三",
//   "age": 20,
//   "city": "南昌",
//   "hobbies": [
//     "读书",
//     "旅游",
//     "羽毛球"
//   ]
// }
  • 如果对象中包含函数、undefined、symbol或循环引用等特殊类型的属性,则在转换为JSON字符串时会被忽略或转换为null。
  • 如果需要控制转换过程中哪些属性应该被包含在JSON字符串中,可以使用replace参数。这里只输出namehobbies
  • 第三个参数表示缩进的空格数,这里设置为2。由于缩进输出的JSON字符串更易于阅读和调试,因此在开发过程中常常会使用这种方式。
  • 可以用JSON.parse()方法将这些 JSON 字符串转换回 JS 对象。

十一、includes()方法、indexOf()方法和lastIndexOf()方法

1.includes()方法

includes方法用于检查数组中是否包含某个元素,如果包含则返回 true,否则返回 false。includes()方法区分大小写

const str = "Hello world";
console.log(str.includes("world")); //true
console.log(str.includes("Hello")); //true
console.log(str.includes("o"));      //true
console.log(str.includes("h"));      //false
console.log(str.includes("H"));      //true
console.log(str.includes("JS"));     //false
console.log(str.includes("WORLD"));  //false

2.indexOf()方法

需要注意的是,indexOf方法只会返回第一个匹配项的位置。如果数组中存在多个相同的元素,该方法只会返回第一个元素的位置,indexOf()方法是区分大小写的。

const str = "Hello world";
console.log(str.indexOf("o"));      //4
console.log(str.indexOf("e"));      //1
console.log(str.indexOf("E"));      //-1
console.log(str.indexOf("llo"));    //2
console.log(str.indexOf("world"));  //6
console.log(str.indexOf("Hello"));  //0
console.log(str.indexOf("hello"));  //-1

3.lastIndexOf()方法

lastIndexOf()方法与indexOf()方法类似,不同之处在于它返回指定字符串或字符在原字符串中最后一次出现的位置,而不是第一次出现的位置。

const str = "Hello world, world";
console.log(str.lastIndexOf("world"));//13
console.log(str.lastIndexOf("l", 8));   //3
console.log(str.lastIndexOf("l"));      //16
console.log(str.lastIndexOf("L"));      //-1
console.log(str.lastIndexOf("k"));      //-1
console.log(str.lastIndexOf("hello")); //-1

我们使用str.lastIndexOf("l", 8)查找字符串"Hello world, world"中字符"l"最后一次出现的位置,但是限定了查找范围只在前8个字符内。也就相当于在字符串"Hello wo"中使用lastIndexOf("l")方法,l最后出现在下标3的位置,所以返回3。

如果lastIndexOf()方法没有找到指定的字符串或字符,它将返回-1。

十二、endsWith()方法和startsWith()方法

1.endsWith()方法

endsWith() 方法用于判断一个字符串是否以指定的子字符串结尾。

const str = "Hello, World!";
console.log(str.endsWith("!"));     //true
console.log(str.endsWith("ld"));   //false
console.log(str.endsWith("l"));     //false
console.log(str.endsWith("W", 7)); //false  "Hello, " 不以W结尾
console.log(str.endsWith("W", 8)); //true   "Hello, W" 以W结尾

endsWith() 方法接受两个参数,第一个参数是要查找的子字符串,第二个参数是查找的终止位置。当省略第二个参数时,默认从结尾开始查找。如果找到指定的子字符串,则返回 true,否则返回 false。

2.startsWith()方法

startsWith() 方法用于判断一个字符串是否以指定的子字符串开头。

const str = "Hello, World!";
console.log(str.startsWith("He"));   //true
console.log(str.startsWith("l"));     //false
console.log(str.startsWith("l", 3));  //true  "lo, World!"以l开头
console.log(str.startsWith("l", 4));  //false  "o, World!"不以l开头
console.log(str.startsWith("e", 1));  //true  "ello, World!"以e开头
console.log(str.startsWith("e", 4));  //false "o, World!"不以e开头

startsWith() 方法接受两个参数,第一个参数是要查找的子字符串,第二个参数是查找的起始位置。当省略第二个参数时,默认从头开始查找。如果找到指定的子字符串,则返回 true,否则返回 false。

十三、normalize()方法

normalize()用于将字符串标准化为一致的Unicode形式。因为在Unicode中,同样的字符可以有多种不同的表示方式,这可能会导致某些比较或排序操作的混淆。normalize() 方法可以将这些不同表示方式的字符转换为一致的形式,以便在比较和排序等操作中得到正确的结果。

normalize() 方法接受一个参数,表示需要使用哪种标准化形式,共有四种:

  1. NFC:使用组合字符标准化形式。
  2. NFD:使用分解字符标准化形式。
  3. NFKC:使用组合字符同时兼容性标准化形式。
  4. NFKD:使用分解字符同时兼容性标准化形式。
const str1 = "café";
const str2 = "cafe\u0301";
console.log(str1.normalize());  //café
console.log(str2.normalize());  //café
console.log(str1 === str2);     //false
console.log(str1.normalize() === str2.normalize()); // true
console.log(str1.normalize('NFD'));   //café
console.log(str1.normalize('NFC'));   //café
console.log(str1.normalize('NFKC'));  //café
console.log(str1.normalize('NFKD'));  //café
console.log(str2.normalize('NFD'));   //café
console.log(str2.normalize('NFC'));   //café
console.log(str2.normalize('NFKC'));  //café
console.log(str2.normalize('NFKD'));  //café

十四、repeat()方法

repeat() 方法用于将字符串重复指定的次数,并返回重复后的字符串。

const str = "冰美式";
console.log(str.repeat(-1)); //报错
console.log(str.repeat(0));  //空字符
console.log(str.repeat(3));  //冰美式冰美式冰美式
console.log(str);  //冰美式

repeat() 方法只接受一个参数,表示需要重复的次数。少于 0 的次数会报错,等于 0 的次数会返回空字符串,大于等于 1 的次数会返回重复后的字符串。

十五、localeCompare()方法

字符串的比较可以使用比较运算符和localeCompare()方法。其中比较运算符可以直接比较两个字符串的大小,localeCompare()方法可以比较两个字符串在字典序中的大小。

返回值是一个数字,目前的主流浏览器都返回的是1、0、-1三个值。

  1. 返回值大于0:说明当前字符串string大于对比字符串targetString
  2. 返回值小于0:说明当前字符串string小于对比字符串targetString
  3. 返回值等于0:说明当前字符串string等于对比字符串targetString
var str1 = "hello";
var str2 = "world";
var str3 = "hello";
console.log(str1 > str2); //false
console.log("a" > "b");   //false
console.log("f" > "c");    //true
console.log(str1.localeCompare(str2)); // -1
console.log(str1.localeCompare(str3)); // 0
console.log(str2.localeCompare(str3)); // 1

 

十六、toUpperCase()方法和toLowerCase()方法

1.toUpperCase()方法

toUpperCase:将字符串中的所有字母变为大写字母,非字母不受影响,不改变原字符串。

const str = "hello world 冰美式";
const upperStr = str.toUpperCase();
console.log(upperStr);  //HELLO WORLD 冰美式
console.log(str);  //hello world 冰美式

 

2.toLowerCase()方法

toLowerCase:将字符串中的所有字母变为小写字母,非字母不受影响,不改变原字符串。

const str = "HELLO WORLD 冰美式";
const lowerStr = str.toLowerCase();
console.log(lowerStr);  //hello world 冰美式
console.log(str);  //HELLO WORLD 冰美式

 

十七、toLocaleUpperCase()方法和toLocaleLowerCase()方法

toLocaleUpperCase()toLocaleLowerCase()是JavaScript中的字符串方法,用于将字符串转换为大写字母和小写字母,与toUpperCase()toLowerCase()方法的区别在于它们使用特定的语言环境设置来进行转换,可以根据用户所处的地区,将不同的字符转换为大写或小写。

1.toLocaleUpperCase()方法

toLocaleUpperCase:将字符串中的所有字母转换为大写字母,同时根据本地化规则将字符转换为特定于语言和区域设置的大小写形式。

// 将字符转换为特定于土耳其语本土化规则的大写形式
const str = "hello world";
const upperStr = str.toLocaleUpperCase('tr-TR');
console.log(upperStr);  //HELLO WORLD

// 希腊语字符示例:
const str = 'Γειά σου';
console.log(str.toLocaleUpperCase()); //ΓΕΙΆ ΣΟΥ

// 阿拉伯语字符示例:
const str2 = 'مرحبا بالعالم';
console.log(str2.toLocaleUpperCase()); //مرحبا بالعالم

2.toLocaleLowerCase()方法

toLocaleLowerCase:将字符串中的所有字母转换为小写字母,同时根据本地化规则将字符转换为特定于语言和区域设置的大小写形式。

//将字符转换为特定于土耳其语本土化规则的小写形式。
const str = "HELLO WORLD";
const lowerStr = str.toLocaleLowerCase('tr-TR');
console.log(lowerStr);  //hello world
//土耳其语中的I转换为ı
const str2 = 'Türkİye Cumhurİyetİ';
console.log(str2.toLocaleLowerCase()); //türkiye cumhuriyeti

十八、toString()方法

toString()方法返回一个对象的字符串形式。对于自定义对象,如果没有为其定义toString()方法,会使用默认的 toString() 实现,即返回 “[Object object]” 字符串。

const num = 666
console.log(num.toString());  //666

const arr = [1, 2, 3];
console.log(arr.toString());  //1,2,3

const b = true;
console.log(b.toString());    //true

const obj = {name: "张三", age: 20};
console.log(obj.toString());  //[object Object]

我们可以通过为自定义对象定义toString()方法来自定义它们的字符串表示形式。

function Person(name, age) {
  this.name = name;
  this.age = age;
}
Person.prototype.toString = function() {
  return `Person(name='${this.name}', age=${this.age})`;
};
const str = new Person("张三", 20);
console.log(str.toString());  //Person(name='张三', age=20)

十九、at()方法和charAt()方法

1.charAt()方法

charAt()方法用于返回指定位置的字符,如果索引超出字符串范围,则返回空字符串。

//返回指定位置的字符
const str = "Hello, World!";
console.log(str.charAt(1));   //e
console.log(str.charAt(8));   //o
console.log(str.charAt(20));  //输出空字符串

2.at()方法

at()方法用于返回指定位置的Unicode字符,如果索引超出字符串范围,则返回undefined。

const str = '

标签:search,slice,console,log,indexOf,str2,str,字符串,const
From: https://www.cnblogs.com/caihongmin/p/17510797.html

相关文章

  • JS中数组22种常用API总结,slice、splice、map、reduce、shift、filter、indexOf......
    一、引言在前端开发中,数组是一种常见且重要的数据结构。数组提供了许多便捷的方法来操作和处理其中的数据。本文将简单介绍前端中数组常用的API,包括添加、删除、截取、合并、转换等操作。二、push()方法和pop()方法push()方法用于向数组末尾添加一个或多个元素,并返回修改......
  • SummerResearch_Log_20230627
    WorkingContent:1.今天开始看VisionTransformer(ViT):看之前需要一些基础:(1)RNN(RecurrentNN,循环神经网络):一段连续的信息,前后信息之间是有关系地,必须将不同时刻的信息放在一起理解。如果是普通的神经网络,每个输入之间是相互独立的,如果是RNN,则可以接收上一个输入传递的信息。......
  • 1、Elasticsearch单机与集群的安装(包安装、二进制安装与Docker安装)
    ElasticsearchElasticsearch是一个实时的全文搜索,存储库和分析引擎https://www.elastic.co/cn/what-is/elasticsearchElasticsearch在速度和可扩展性方面都表现出色,而且还能够索引多种类型的内容,可用于多种场景:应用程序搜索网站搜索企业搜索日志处理和分析基础设施指标和......
  • ElasticSearch - activemq - tomcat 开机自启动
    [root@qwy~]#cat/etc/init.d/elastisearch|grep-v'^#'#!/bin/bash#chkconfig:23455525#description:SSHisaprotocolforsecureremoteshellaccess.exportJAVA_HOME=/usr/local/java/jdk/exportJAVA_BIN=/usr/local/java/jdk/binexportP......
  • elasticsearch
    1.初识elasticsearch作用:elasticsearch是一款非常强大的开源搜索引擎,具备非常多强大功能,可以帮助我们从海量数据中快速找到需要的内容ELK技术栈:elasticsearch结合kibana、Logstash、Beats,也就是elasticstack(ELK)。被广泛应用在日志数据分析、实时监控等领域。而elasticsearch是e......
  • docker部署elasticsearch
    CentOS7下使用docker安装ELK日志框架前言:elk是由Elasticsearch、Logstash、Kibana三个开源组件组合形成的框架。Elasticsearch是个开源分布式搜索引擎,提供搜集、分析、存储数据三大功能。它的特点有:分布式,零配置,自动发现,索引自动分片,索引副本机制,restful风格接口,多数据源,自动搜......
  • Go常见错误集锦之混淆slice中的长度(length)和容量(capacity)
    原文文章:https://zhuanlan.zhihu.com/p/413972333 在Go语言中,slice的底层实现是数组,也就是说,切片的数据实际上是被存储在数组中的。如果后端的数组空间已经满了或是空数组,则slice结构体负责处理数组容量的扩容或缩容逻辑。此外,slice的结构体中共拥有三个字段:一个指针,指向后......
  • GO 语言中 slice 的理解
    GO语言中 slice理解为什么说Go语言的slice是引用类型,其底层实现明明是一个结构体?slice的底层实现是一个包含三个字段的结构体:指向底层数组的指针、slice的长度和slice的容量。当我们对slice进行操作时,例如添加或删除元素,实际上是在底层数组中进行操作。由于slice......
  • Elasticsearch专题精讲—— REST APIs —— Cluster APIs —— Cluster update settin
    RESTAPIs——ClusterAPIs——ClusterupdatesettingsAPIhttps://www.elastic.co/guide/en/elasticsearch/reference/8.8/cluster-update-settings.html#cluster-update-settingsConfiguresdynamicclustersettings.配置动态群集设置......
  • Elasticsearch专题精讲—— REST APIs —— Cluster APIs —— Cluster stats API
    RESTAPIs——ClusterAPIs——ClusterstatsAPIhttps://www.elastic.co/guide/en/elasticsearch/reference/8.8/cluster-stats.html#cluster-statsReturnsclusterstatistics.返回集群统计信息。1、Request(请求)https://www.elastic.co......