JS算法必备之String常用操作方法

简介: 这篇文章详细介绍了JavaScript中字符串的基本操作,包括创建字符串、访问特定字符、字符串的拼接、位置查找、大小写转换、模式匹配、以及字符串的迭代和格式化等方法。

MDN参考文档: String - JavaScript | MDN

①创建字符串

// var stringObject = new String('hello world')

var stringValue = 'hello world' // 其每一个实例都有一个length属性

console.log(stringValue.length) // 11

②字符方法

用于访问字符串中特点字符的方法:

1.charAt()

console.log(stringValue.charAt(1)) // 'e'

console.log(stringValue[1]) // 'e',用方括号[ ]访问字符

2.charCodeAt()

若想得到的不是字符而是字符编码:

console.log(stringValue.charCodeAt(1)) // '101'(即'e'的字符编码)

③字符串操作方法

1.concat():用于将一个或多个字符串拼接起来,返回拼接后的新字符串

var str = 'hello'

var result1 = str.concat(' world')

console.log(result1) // 'hello world'

var result2 = str.concat(' world' + '!')

console.log(result2) // 'hello world!'

在大多数情况下更喜欢使用加号操作符(+)拼接多个字符串

基于子字符串创建新字符串的方法:

2.slice()和substring():第一个参数指定子字符串的开始位置,第二个参数指定子字符串最后一个字符后面的位置。

若没有第二个参数,则将字符串末尾作为结束位置

var stringValue = 'hello world'

console.log(stringValue.slice(1, 5)) // 'ello'

console.log(stringValue.substring(1, 5)) // 'ello'

console.log(stringValue.substring(1)) // 'ello world'

3.substr():第一个参数指定子字符串的开始位置,第二个参数指定返回的字符个数。

若没有第二个参数,则将字符串末尾作为结束位置

console.log(stringValue.substr(2, 5)) // 'llo w'

console.log(stringValue.substr(2)) // 'llo world'

④字符串位置方法

1.indexOf():从字符串的开头向后搜索子字符串,返回第一个匹配子字符串的位置,若没有找到,则返回-1。

var stringValue = 'hello world'

console.log(stringValue.indexOf('o')) // 4

console.log(stringValue.indexOf('ello')) // 1

2.lastIndexOf():从字符串的末尾向前搜索子字符串,返回第一个匹配子字符串的位置,若没有找到,则返回-1。

console.log(stringValue.lastIndexOf('o')) // 7

两个方法还可以接收可选的第二个参数:表示从字符串中的哪个位置开始搜索

console.log(stringValue.indexOf('o', 6)) // 7

console.log(stringValue.lastIndexOf('o', 6)) // 4

⑤字符串迭代方法

var str = 'hello'

for (let i = 0; i < str.length; i++) {

  console.log(str\[i\]) // 字符串每项的值

}

for (const n of str) {

  console.log(n) // 字符串每项的值

}

for (const i in str) {

  console.log(i) // 字符串每项的索引值(string类型)

}

⑥trim()**方法**

创建一个字符串的副本,删除前置及后缀的所有空格。

var stringValue = ' hello world '

console.log(stringValue.trim()) // 'hello world'

⑦**includes()方法**

方法用于判断一个字符串是否包含在另一个字符串中,根据情况返回 true 或 false

var stringValue = 'hello world'

console.log(stringValue.includes('e')) // true

console.log(stringValue.includes('ello')) // true

console.log(stringValue.includes('eo')) // false

⑧startsWith**()方法**

方法用来判断当前字符串是否以另外一个给定的子字符串开头,并根据判断结果返回 true 或 false

var stringValue = 'hello world'

console.log('starts:', stringValue.startsWith('he')) // true

console.log('starts:', stringValue.startsWith('eo')) // false

字符串大小写转换方法

var stringValue = 'hello world'

console.log(stringValue.toLocaleUpperCase()) // 'HELLO WORLD'

console.log(stringValue.toUpperCase()) // 'HELLO WORLD'

console.log(stringValue.toLocaleLowerCase()) // 'hello world'

console.log(stringValue.toLowerCase()) // 'hello world'

Locale:是针对特定地区的实现,若不知道自己的代码在哪种语言环境中运行,还是使用针对地区的方法更稳妥一些。

⑨字符串模式匹配方法

1.match():只接收一个参数,正则表达式或者RegExp对象,结果会返回一个数组。

方法的行为在很大程度上有赖于 regexp 是否具有标志 g。如果 regexp 没有标志 g,那么 match() 方法就只能在 stringObject 中执行一次匹配。如果没有找到任何匹配的文本, match() 将返回 null。否则,它将返回一个数组,其中存放了与它找到的匹配文本有关的信息。

console.log(str.match(/ain/g)) // ['ain', 'ain', 'ain']

console.log(str.match(/ain/gi)) // ['ain', 'AIN', 'ain', 'ain']

console.log(str.match(/k/gi)) // null

2.search():只接收一个参数,用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串。

结果返回字符串中第一个匹配项的索引,若没有匹配项,则返回-1。

var stringValue = 'hello world'

console.log(stringValue.search('world')) // 6

console.log(stringValue.search(/WORLD/)) // -1

console.log(stringValue.search(/WORLD/i)) // 6

3.replace():替换子字符串的方法,接收两个参数:第一个参数是一个RegExp对象或者一个字符串(不会被转换成正则表达式),第二个参数是一个字符串或者一个函数。

var text = 'cat,bat,sat,fat'

var result = text.replace('at', 'ond')

console.log(result) // 'cond,bat,sat,fat'

// 提供一个正则表达式,并指定全局(g)标志

result = text.replace(/at/g, 'ond')

console.log(result) // 'cond,bond,sond,fond'

4.split():基于指定的分隔符将一个字符串分割成多个子字符串,并将结果放在一个数组中。分隔符可以说字符串或者一个RegExp对象,还可以接受第二个可选参数,用于指定数组的大小。

var colorText = 'red,blue,green,yellow'

var colors1 = colorText.split(',') // ['red', 'blue', 'green', 'yellow']

var colors2 = colorText.split(',', 2) // ['red', 'blue']

⑩localeCompare()**方法**

var stringValue = 'yellow'

// 具体返回的正数和负数未必是1和-1,需看实现

console.log(stringValue.localeCompare('brick')) // 1

console.log(stringValue.localeCompare('yellow')) // 0

console.log(stringValue.localeCompare('zoo')) // -1

⑪**fromCharCode()**方法

String构造函数本身还有一个静态方法:fromCharCode(),接收一个或多个字符编码,然后将它们转换成一个字符串

console.log(String.fromCharCode(104,101,108,108,111)) // 'hello'

相关文章
|
18天前
|
运维 监控 JavaScript
内网网管软件中基于 Node.js 的深度优先搜索算法剖析
内网网管软件在企业网络中不可或缺,涵盖设备管理、流量监控和安全防护。本文基于Node.js实现深度优先搜索(DFS)算法,解析其在网络拓扑遍历中的应用。通过DFS,可高效获取内网设备连接关系,助力故障排查与网络规划。代码示例展示了图结构的构建及DFS的具体实现,为内网管理提供技术支持。
38 11
|
4月前
|
机器学习/深度学习 算法 数据挖掘
K-means聚类算法是机器学习中常用的一种聚类方法,通过将数据集划分为K个簇来简化数据结构
K-means聚类算法是机器学习中常用的一种聚类方法,通过将数据集划分为K个簇来简化数据结构。本文介绍了K-means算法的基本原理,包括初始化、数据点分配与簇中心更新等步骤,以及如何在Python中实现该算法,最后讨论了其优缺点及应用场景。
225 6
|
5天前
|
算法 JavaScript 前端开发
Javascript常见算法详解
本文介绍了几种常见的JavaScript算法,包括排序、搜索、递归和图算法。每种算法都提供了详细的代码示例和解释。通过理解这些算法,你可以在实际项目中有效地解决各种数据处理和分析问题。
46 21
|
5月前
|
存储 算法 Java
解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用
在Java中,Set接口以其独特的“无重复”特性脱颖而出。本文通过解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用。
93 3
|
15天前
|
监控 网络协议 算法
基于问题“如何监控局域网内的电脑”——Node.js 的 ARP 扫描算法实现局域网内计算机监控的技术探究
在网络管理与安全领域,监控局域网内计算机至关重要。本文探讨基于Node.js的ARP扫描算法,通过获取IP和MAC地址实现有效监控。使用`arp`库安装(`npm install arp`)并编写代码,可定期扫描并对比设备列表,判断设备上线和下线状态。此技术适用于企业网络管理和家庭网络安全防护,未来有望进一步提升效率与准确性。
32 8
|
2月前
|
机器学习/深度学习 人工智能 算法
机器学习算法的优化与改进:提升模型性能的策略与方法
机器学习算法的优化与改进:提升模型性能的策略与方法
412 13
机器学习算法的优化与改进:提升模型性能的策略与方法
|
2月前
|
JavaScript 算法 安全
深度剖析:共享文件怎么设置密码和权限的 Node.js 进阶算法
在数字化时代,共享文件的安全性至关重要。本文聚焦Node.js环境,介绍如何通过JavaScript对象字面量构建数据结构管理文件安全信息,包括使用`bcryptjs`库加密密码和权限校验算法,确保高效且安全的文件共享。通过实例代码展示加密与权限验证过程,帮助各行业实现严格的信息资产管理与协作。
|
2月前
|
存储 监控 算法
局域网网络管控里 Node.js 红黑树算法的绝妙运用
在数字化办公中,局域网网络管控至关重要。红黑树作为一种自平衡二叉搜索树,凭借其高效的数据管理和平衡机制,在局域网设备状态管理中大放异彩。通过Node.js实现红黑树算法,可快速插入、查找和更新设备信息(如IP地址、带宽等),确保网络管理员实时监控和优化网络资源,提升局域网的稳定性和安全性。未来,随着技术融合,红黑树将在网络管控中持续进化,助力构建高效、安全的局域网络生态。
63 9
|
3月前
|
监控 算法 JavaScript
基于 Node.js Socket 算法搭建局域网屏幕监控系统
在数字化办公环境中,局域网屏幕监控系统至关重要。基于Node.js的Socket算法实现高效、稳定的实时屏幕数据传输,助力企业保障信息安全、监督工作状态和远程技术支持。通过Socket建立监控端与被监控端的数据桥梁,确保实时画面呈现。实际部署需合理分配带宽并加密传输,确保信息安全。企业在使用时应权衡利弊,遵循法规,保障员工权益。
67 7
|
2月前
|
存储 监控 JavaScript
深度探秘:运用 Node.js 哈希表算法剖析员工工作时间玩游戏现象
在现代企业运营中,确保员工工作时间高效专注至关重要。为应对员工工作时间玩游戏的问题,本文聚焦Node.js环境下的哈希表算法,展示其如何通过快速查找和高效记录员工游戏行为,帮助企业精准监测与分析,遏制此类现象。哈希表以IP地址等为键,存储游戏网址、时长等信息,结合冲突处理与动态更新机制,确保数据完整性和时效性,助力企业管理层优化工作效率。
38 3

热门文章

最新文章