JS关于 replace 取值、替换第几个匹配项问题小结
作者:橙子家 发布时间:2024-04-25 13:11:05
标签:js,replace,取值,替换,匹配项
在日常开发中,经常遇到针对字符串的替换、截取,知识点比较碎容易混淆,特此总结一下,仅供参考。
一、替换第一个匹配项
字符串替换
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>
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) ["要提取的内容", "另一个内容"]
来源:https://www.cnblogs.com/czzj/p/js_replace.html


猜你喜欢
- 需要引用vue-resource安装请参考https://github.com/pagekit/vue-resource官方文档在入口函数中
- 本文实例总结了python选择排序算法。分享给大家供大家参考。具体如下:代码1:def ssort(V):#V is the list to
- 原型图:项目需求:服务器接受到报警后将消息推送到前台,(通过前端实时消息提示的效果-websocket长轮询),前台接受到消息后需要发出警报
- 废话就不多说了,直接上内容。<form action="/home/search" method="ge
- 一.使用DOM生成和读取XML文件 实例一: <?php //Creates XML string and XML document
- 本文实例为大家分享了python读取图片并修改文件大小的具体代码,供大家参考,具体内容如下# Author:NDK# -*- coding:
- 1. 引言在日常工作中,大家都需要进行字典的相关操作,对于某些初学者,经常会写一堆繁琐的代码来实现某项简单的功能。本篇文章重点介绍一些在Py
- global.asa<SCRIPT LANGUAGE="VBScript" RUNAT=&qu
- 目录实际项目中遇到的需求有一些不好的实现方式个人感觉比较好的实现方式功能已实现,但我又开始了新的思考最终方案——高阶组件实际项目中遇到的需求
- Metro风格设计主要特点 1.Windows 8 Metro风格设计,实现网站或系统功能的导航 2.纯Javascript实现 3.支持所
- 经常会有小朋友问我,“我想做个黑客,我该学什么编程语言?”,或者有的小朋友会说:“我要学c,我要做病毒”。其实对于这些小朋友而言他们基本都没
- #!/usr/bin/env python # coding=utf-8 #--------------------------------
- pytest官方文档fixtures调用既然fixtures是给执行测试做准备工作的,那么pytest如何知道哪些测试函数 或者 fixtu
- 1.init 函数简介Golang init 函数是一种特殊的函数,主要用于完成程序的初始化工作,如初始化数据库的连接、载入本地配置文件、根
- collections中defaultdict的用法一、字典的键映射多个值将下面的列表转换成字典一个字典就是一个键对应一个单值得映射,而上面
- 在网站或软件的策划和设计过程中,我们经常听到这样的讨论:“这个功能设计得太重了”又或“我们希望能够处理得轻一些”。似乎轻设计是时下炙手可热的
- 代码import turtleturtle.bgcolor("black")turtle.pensize(2)sizeh
- jquery基本入门 第一天:选择器相关 1.html()与.text() .html()取得第一个匹配元素的html内容。会带有标签,.t
- 本文实例讲述了python队列原理及实现方法。分享给大家供大家参考,具体如下:队列(queue)是只允许在一端进行插入操作,而在另一端进行删
- 原文地址:30 Days of Mootools 1.2 Tutorials - Day 7 - Set and Get Style Pro