js 关于 replace 取值、替换第几个匹配项(两种方式:正则、普通字符串操作)

js,关于,replace,取值,替换,第几个,匹配,两种,方式,正则,普通,字符串,操作 · 浏览次数 : 493

小编点评

首先需要将所有匹配项的内容提取出来并存储在数组中,然后将这些内容带入生成内容的模板中进行处理。 模板中需要带一些简单的排版指令,例如对数组元素进行索引,对字符串进行转义等。 例如,以下模板中需要对数组元素进行索引,对字符串进行转义等: ``` {{arr[0] | replace(/</, '</', '')}} ``` 其中,`arr`是一个包含匹配项的数组。 最终,生成内容的模板需要根据具体需求进行修改,并带一些简单的排版指令进行处理。

正文

〇、前言

在日常开发中,经常遇到针对字符串的替换、截取,知识点比较碎容易混淆,特此总结一下,仅供参考。

一、替换第一个匹配项

字符串替换

let strtest = "0123测试replace456测试replace789测试replace0"
console.log("原字符串:" + strtest)
let outstr = strtest.replace("测试","ceshi")
console.log("输出字符串:" + outstr)

// 原字符串:0123测试replace456测试replace789测试replace0
// 输出字符串:0123ceshireplace456测试replace789测试replace0

正则表达式替换

 当直接在被替换字符串恰后加上 / 时,不添加修饰符,就等同于直接字符串替换。

let strtest = "0123测试replace456测试replace789测试replace0"
console.log("原字符串:" + strtest)
let outstr = strtest.replace(/测试/, "ceshi")
console.log("输出字符串:" + outstr)

// 原字符串:0123测试replace456测试replace789测试replace0
// 输出字符串:0123ceshireplace456测试replace789测试replace0

二、替换全部匹配项

字符串分组再联合

let strtest = '0123测试replace456测试replace789测试replace0';
console.log("原字符串:" + strtest)
let arrstr = strtest.split("测试");
let outstr = arrstr.join("ceshi");
console.log("输出字符串:" + outstr)

// 原字符串:0123测试replace456测试replace789测试replace0
// 输出字符串:0123ceshireplace456ceshireplace789ceshireplace0

正则表达式替换

 格式:/待替换的字符串/g、/待替换的字符串/mgi。

  g:执行全局匹配,替换全部匹配项;

  i:不区分大小写;

  m:多行匹配。

gim 可所以组合使用。

let strtest = "0123测试replace456测试replace789测试replace0"
console.log("原字符串:" + strtest)
let outstr = strtest.replace(/测试/g, "ceshi")
// 另一种写法:
// let reg = new RegExp("测试", "g")
// let outstr = strtest.replace(reg, "ceshi")
console.log("输出字符串:" + outstr)

// 原字符串:0123测试replace456测试replace789测试replace0
// 输出字符串:0123ceshireplace456ceshireplace789ceshireplace0

三、替换第 n 个匹配项

下边以第二个为例。

字符串分组再联合

思路:先通过被替换项分组,再根据目标位数把整个分组分为两个部分,在通过替换字符串联合。

let num = 2 // 定义替换第二个匹配项
let strtest = '0123测试replace456测试replace789测试replace0';
console.log("原字符串:" + strtest)
let arrstr = strtest.split("测试");
if(arrstr.length < num)
    return
let arrstr1=[],arrstr2=[]
for(let ii=0;ii<arrstr.length;ii++){
    if(ii < num)
        arrstr1.push(arrstr[ii])
    else
        arrstr2.push(arrstr[ii])
}
let outstr = arrstr1.join("测试")+"ceshi"+arrstr2.join("测试");
console.log("输出字符串:" + outstr)

// 原字符串:0123测试replace456测试replace789测试replace0
// (index):59 输出字符串:0123测试replace456ceshireplace789测试replace0

正则表达式实现

将第一个匹配项跳过,并把第二个匹配项之前的内容标识为变量。

let strtest = '0123测试replace456测试replace789测试replace0';
console.log("原字符串:" + strtest)
let outstr = strtest.replace(/((?:.*?测试.*?){1}.*?)测试/m, "$1-ceshi-")
// ?: 表示:其后边的 pattern 匹配但不获取。匹配项被标识为 $1,后续会引用
// .*? 表示:.* 除 '/n' 之外的任意个任意字符
// {1} 表示:其前边的 pattern 出现一次
// /pattern/m 表示: m 全局查询
console.log("输出字符串:" + outstr)

// 原字符串:0123测试replace456测试replace789测试replace0
// 输出字符串:0123测试replace456测试replace789-ceshi-replace0

  参考:https://stackoverflow.com/questions/42943096/replace-nth-match-of-matches-with-regex

四、替换指定标记之间的内容

字符串分组再联合

let strtest = '0123<Object>replace456测试replace78</Object>9测试replace0';
let startstr = "<Object>"
let endstr = "</Object>"
if (strtest.indexOf(startstr) > strtest.indexOf(endstr))
    return
console.log("原字符串:" + strtest)
let arr = strtest.split(startstr)
let arr2 = arr[1].split(endstr)
let resultstr = arr2[0]
let outstr = startstr + resultstr + endstr
console.log("输出字符串:" + outstr)

// 原字符串:0123<Object>replace456测试replace78</Object>9测试replace0
// 输出字符串:<Object>replace456测试replace78</Object>

正则表达式方法 replace()、match()、exec()

替换为指定字符串:( replace() )

let strtest = '0123<Object>replace456测试replace78</Object>9测试replace0';
console.log("原字符串:" + strtest)
let outstr = strtest.replace(/<Object>(.*?)<\/Object>/m, "-ceshi-") // \ 为转义字符
console.log("输出字符串:" + outstr)

// 原字符串:0123<Object>replace456测试replace78</Object>9测试replace0
// 输出字符串:0123-ceshi-9测试replace0

取出带标记字符串的内容:( match() )

let strtest = '0123<Object>replace456测试replace78</Object>9测试replace0';
console.log("原字符串:" + strtest)
let outstr = strtest.match(/<Object>(.*?)<\/Object>/m)
console.log("输出字符串:" + outstr)

// 原字符串:0123<Object>replace456测试replace78</Object>9测试replace0
// 输出字符串:<Object>replace456测试replace78</Object>

当可能有多个匹配项时:( exec() )

let strtest = "这是<Object>要提取的内容</Object>,还有<Object>另一个内容</Object>"
console.log("原字符串:" + strtest)
let regex = /<Object>(.*?)<\/Object>/gm
const matches = []
let match
while ((match = regex.exec(strtest)) !== null) {
    matches.push(match[1])
    console.log(match)
}
console.log("输出全部匹配项:", matches)

// 原字符串:这是<Object>要提取的内容</Object>,还有<Object>另一个内容</Object>
// (2) ["<Object>要提取的内容</Object>", "要提取的内容", index: 2, input: "这是<Object>要提取的内容</Object>,还有<Object>另一个内容</Object>", groups: undefined]
// (2) ["<Object>另一个内容</Object>", "另一个内容", index: 28, input: "这是<Object>要提取的内容</Object>,还有<Object>另一个内容</Object>", groups: undefined]
// 输出全部匹配项: (2) ["要提取的内容", "另一个内容"]

与js 关于 replace 取值、替换第几个匹配项(两种方式:正则、普通字符串操作)相似的内容:

js 关于 replace 取值、替换第几个匹配项(两种方式:正则、普通字符串操作)

在日常开发中,经常遇到针对字符串的替换、截取,知识点比较碎容易混淆,特此总结一下,仅供参考。

第一百零六篇:变量的不同声明(var,let和const的不同)

JS关于变量的声明,变量提升,暂时性死区

将 Vue.js 项目部署至静态网站托管,并开启 Gzip 压缩

摘要:关于使用 Nginx 开启静态网站 Gzip 压缩的教程已经有很多了,但是好像没几个讲怎么在对象存储的静态网站中开启 Gzip 压缩。其实也不复杂,我们一起来看下~ 本文分享自华为云社区《将 Vue.js 项目部署至静态网站托管,并开启 Gzip 压缩》,作者:云存储开发者支持团队。 关于使用

01背包问题的js解决方式

如果你有兴趣看这个相信你已经对背包问题有所了解,所以关于背包问题的描述,我就不写了。只记录一下自己对这个问题的一些看法和思考,于我而言,这个东西现在困扰我的是如何确定最优解。实质上关于背包问题网上的东西我大体都有看过,对于这个问题,常见的就是使背包重量动态增长,然后遍历每个要装入的这些包裹,当包裹的

vue的两种服务器端渲染方案

关于服务器端渲染方案,之前只接触了基于react的Next.js,最近业务开发vue用的比较多,所以调研了一下vue的服务器端渲染方案。本文着重介绍两种渲染方案。

第一百一十六篇: JavaScript理解对象

好家伙,本篇为《JS高级程序设计》第八章“对象、类与面向对象编程”学习笔记 1.关于对象 ECMA-262将对象定义为一组属性的无序集合。严格来说,这意味着对象就是一组没有特定顺序的值。 对象的每个属性或方法都由一个名称来标识,这个名称映射到一个值。正因为如此(以及其他还未讨论的原因),可以把 EC

第119篇: JavaScript 类

好家伙,我们先来复习一下 关于Java,类的三大特征: 1、封装,也就是把客观事物封装成抽象的类,并且类可以把自己的数据和方法只让可信的类或者对象操作,对不可信的进行信息隐藏。 2、继承,继承性更符合认知规律,使程序更易于理解,同时节省不必要的重复代码。 3、多态,体现为覆盖和重载,Js没有重载,有

VSCode中打开NodeJS项目自动切换对应版本的配置

这几年搞了不少静态站点,有的是Hexo的,有的是VuePress的。由于不同的主题对于NodeJS的版本要求不同,所以本机上不少NodeJS的版本。 关于如何管理多个NodeJS版本,很早之前就写过用nvm来管理的相关文章,这里就不赘述了,有需要的可以看这篇[Node.js环境搭建](https:/

如何使用 JS 判断用户是否处于活跃状态

有时候,我们需要在网页判断用户是否处与非活跃状态,如果用户长时间没有在页面上进行任何操作,我们则判定该用户是非活跃的。 在 javascript 中我们可以通过监听某些鼠标或键盘相关的事件来判定用户是否在活跃中。

JS 实现鼠标框选(页面选择)时返回对应的代码或文本内容

当用户进行鼠标框选选择了页面上的内容时,把选择的内容进行上报。 分为以下几点: 选择文案时 选择图片、svg、iframe、video、audio 等标签时 选择 input、select、textarea 等标签时 选择input、textarea 标签内容时 选择类似   字符时 键盘全选时 鼠...