javascript

位置:IT落伍者 >> javascript >> 浏览文章

js replace 与replaceall实例用法详解


发布日期:2018年08月28日
 
js replace 与replaceall实例用法详解
这篇文章介绍了js replace 与replaceall实例用法详解有需要的朋友可以参考一下

stringObjreplace(rgExp replaceText)
参数
stringObj
必选项要执行该替换的 String 对象或字符串文字该字符串不会被 replace 方法修改
rgExp
必选项为包含正则表达式模式或可用标志的正则表达式对象也可以是 String 对象或文字如果 rgExp 不是正则表达式对象它将被转换为字符串并进行精确的查找;不要尝试将字符串转化为正则表达式
replaceText
必选项是一个String 对象或字符串文字对于stringObj 中每个匹配 rgExp 中的位置都用该对象所包含的文字加以替换在 Jscript 或更新版本中replaceText 参数也可以是返回替换文本的函数
说明
replace 方法的结果是一个完成了指定替换的 stringObj 对象的复制
下面任意的匹配变量都能用来识别最新的匹配以及找出匹配的字符串在需要动态决定替换字符串的文本替换中可以使用匹配变量
字符 含义
$$ $ (JScript 或更新版本)
$& 指定与整个模式匹配的 stringObj 的部分 (JScript 或更新版本)
$` 指定由 $& 描述的匹配之前的 stringObj 部分 (JScript 或更新版本)
$ 指定由 $& 描述的匹配之后的 stringObj 部分 (JScript 或更新版本)
$n 捕获的第 n 个子匹配此处 n 为从的十进制一位数 (JScript 或更新版本)
$nn 捕获的第 nn 个子匹配此处 nn 为从的十进制两位数 (JScript 或更新版本)
如果 replaceText 为函数对于每一个匹配的子字符串调用该函数时带有下面的 m+ 个参数此处 m 是在 rgExp 中捕获的左括弧的个数第一个参数是匹配的子字符串接下来的 m 个参数是查找中捕获的全部结果第 m+ 个参数是在 stringObj 中匹配出现的偏移量而第 m+ 个参数为 stringObj结果为将每一匹配的子字符串替换为函数调用的相应返回值的字符串值
Replace 方法更新全局 RegExp 对象的属性
示例
下面的示例演示了 replace 方法将第一次出现的单词 "The" 替换为单词 "A" 的用法

复制代码 代码如下:
function ReplaceDemo(){
var r re; // 声明变量
var ss = "The man hit the ball with the batn";
ss += "while the fielder caught the ball with the glove";
re = /The/g; // 创建正则表达式模式
r = ssreplace(re "A"); // 用 "A" 替换 "The"
return(r); // 返回替换后的字符串
}
另外 replace 方法也可以替换模式中的子表达式 下面的范例演示了交换字符串中的每一对单词
function ReplaceDemo(){
var r re; // 声明变量
var ss = "The rain in Spain falls mainly in the plain";
re = /(S+)(s+)(S+)/g; // 创建正则表达式模式
r = ssreplace(re "$$$"); // 交换每一对单词
return(r); // 返回结果字符串
}


下 面的示例(在 JScript 及更新版本中执行)执行的是从华氏到摄氏的转换它演示了使用函数作为 replaceText要想知道该函数是如何工作的传递一个包含数值的字符串数值后要紧跟 "F" (例如 "Water boils at ")

复制代码 代码如下:
function fc(s) {
var test = /(d+(d*)?)Fb/g; // 初始化模式
return(sreplace
(test
function($$$) {
return((($) * /) + "C");
}
)
);
}
documentwrite(fc("Water freezes at F and boils at F"));


js居然不提供replaceAll方法用for循环又有效率问题给你一个正则表达式的解决方案
js 代码

复制代码 代码如下:
StringprototypereplaceAll = function(ss){
return thisreplace(new RegExp(s"gm")s);
}


方法 stringreplace(new RegExp(oldString"gm")newString))
gm g=global m=multiLine 大致上方法就是这样的可以实现替换全部指定字串
另一个简单的验证JS的方法
在浏览器地址栏输入
javascript:alert("abcabcabc"replace(new RegExp("a""gm")"ad"))
这样比较省事 ;) 不知道多行的会不会很方便
orgStrreplace(new RegExp(findStr g) replaceStr)
应该就可以替换所有的了
如果不用正则表达式
orgStrreplace(findStr replaceStr)只能替换第一个

上一篇:js中如何把字符串转化为对象、数组示例代码

下一篇:jquery实现隐藏与显示动画效果/输入框字符动态递减/导航按钮切换