【javascript杂谈】你所不知道的replace函数
前言
最近在做面试题的时候总会用到这个函数,这个函数总是和正则表达式联系到一起,并且效果很是不错,总能很简单出色的完成字符串的实际问题,大家肯定都会使用这个函数,像我一样的初学者可能对这个函数的了解还是不够深的,今天就总结一下,了解一下,再做几道网上的题目练练手,给将要面试的同学打打气。
介绍
使用一个替换值替换掉一个替换模式在原字符串中一个或所有的匹配项,并返回替换后的字符串,这个替换模式可以是字符串或者正则表达式,替换值可以是一个字符串或者是一个函数。
后面的大的黑体就是我们开始没有注意到的。
语法
newstring = str.replace(regexp|substr, newSubStr|function[,
flags]);这是官方的解释不是很清楚,一会好好解释下。
参数
regexp
- 一个 REGEXP(正则)对象,该正则所匹配的内容会被第二个参数的返回值替换掉。
substr
- 被
替换掉的
一个字符串
newSubStr
- 替换掉第一个参数在原字符串中的匹配部分,该字符串中可以内插一些特殊的变量名。对于正则replace约定了一个特殊标记符$:
-
- $n (n:1-99) : 表示从左到右正则子表达式所匹配的文本。各个分组匹配的字符串
- $&:表示与正则表达式匹配的全文本。
- $`(`:切换技能键):表示匹配字符串的左边文本。
- $’(‘:单引号):表示匹配字符串的右边文本。
- $$:表示$转移。
function
- 是一个函数,可以有返回值,也可以无返回值。参数的个数不固定,参数挺麻烦的,咱主要就是说这个函数,
-
- 第一个参数为每次匹配的全文本($&),就是整个匹配的字符串
- 中间参数为子表达式匹配字符串,个数不限.( $n (n:1-99)),有分组的时候
- 倒数第二个参数为匹配文本字符串的匹配下标位置。
- 最后一个参数表示字符串本身。
这个函数在执行replace时执行,如果有返回值,返回值用来替换replace的第一个参数。
flags
- 就是正则表达式那些特殊的标志,可有可无的,当第一个参数是字符串的时候使用。
-
g
全局替换i
忽略大小写m
多行模式y
sticky
注意:replace函数并不改变原来的字符串,而是返回来一个新的字符串。
好多例子
说估计大家也是不明白,现在我把所有的情况弄个例子,帮助大家理解:
例子1:
- //replace(str,str);
var str = "I am hainan";- var newStr = str.replace("hainan","Allenxing");
- console.log(newStr);//I am Allenxing
- console.log(str);//I am hainan
例子2:
- // replace(str,str,flag)
- var str = "I am hainan hainan";
- var newStr = str.replace("hainan","Allenxing","gi");
- console.log(newStr);//I am Allenxing Allenxing(FireFox下) I am Allenxing Allenxing(chrome IE下)
- console.log(str);//I am hainan hainan
这种各情况个浏览器支持的不好,建议使用带标记的正则表达式,而不是使用字符串的这种标记,官方这样说
A string specifying a combination of regular expression flags. The use of the flags parameter in the String.replace method is non-standard, use a RegExp object with the corresponding flags.
例子3:
- // replace(RegExp,str)
- var str = "I am hainan hainan";
- var newStr1 = str.replace(/hainan/,"Allenxing");
- console.log(newStr1);//I am Allenxing hainan
- var newStr2 = str.replace(/hainan/g,"Allenxing");
- console.log(newStr2);//I am Allenxing Allenxing
- var str1 = "I am hainan Hainan";
- console.log(str1.replace(/hainan/ig,"Allenxing"));//I am Allenxing Allenxing
- console.log(str1.replace(/hainan/g,"Allenxing"));//I am Allenxing Hainan
例子4:$1是匹配第一个分组的内容,$2是匹配第一个分组的内容......
- //replace(RegExp,'特殊标记')
- var str = "I am hainan hainan";
- console.log( str.replace(/(hainan)/,"*$1*") );//I am *hainan* hainan
解释一下:/(hainan)/ 匹配的是第一个hainan,我们使用"*$1*"的意思就是"*hainan*",用它替换hainan,是第二个参数替换前面的整体。
例子5:
- //replace(RegExp,'特殊标记')
- var str = "I am hainan Allenxing";
- console.log( str.replace(/(hainan)\s*(Allenxing)/g,"$2 $1") );//I am Allenxing hainan
例子6:
- //replace(RegExp,'特殊标记')
- var str = "I am hainan Allenxing";
- console.log( str.replace(/(hainan)\s*(?:Allenxing)/g,"$2 $1") );//I am $2 hainan
解释:(?:)是非捕获分组,匹配内容但是不捕获,也就是$2中现在没有内容,那么就按照$2是个字符串输出。
例子7:$&代表正则匹配的整体
- //replace(RegExp,'特殊标记')
- var str = "hainan";
- console.log( str.replace(/(h)ainan/g,"$& starts with $1") );//hainan starts with h
例子8:$`表示匹配字符串的左边文本,$’(‘:单引号)表示匹配字符串的右边文本。
- //replace(RegExp,"特殊标记")
- var str = "javascript";
- console.log(str.replace(/java/,"$&$' is "));//javascript is script
- console.log(str.replace(/script/,"$& is not $`"));//avascript is not java
参数是function
我们前面简单介绍了参数function,我们写个例子看看这个函数的参数都有什么东西,
- //replace(RegExp,function)
- var str = "I am hainan Allenxing";
- console.log( str.replace(/(hainan)\s*(Allenxing)/g,function(){
- console.(arguments);//看看参数的样子
- }) );
看截图吧,清楚些
这样可以清楚的看出来,函数的第一个参数是正则匹配的全文本(hainan Allenxing),第二个是第一个分组匹配的文本(hainan),第三个是第二个分组匹配的文本(Allenxing),第四个参数是匹配文本字符串的匹配下标位置,第五个参数是整个输入的字符串(I am hainan Allenxing)。后面的几个参数的位置肯能会改变,因为再有分组的话,中间分组的参数个数会增加。
再看下结果,I am undefined ,由于我们function没有明确返回值,所以就是undefined,用undefined替换了正则匹配的全文本。
还有一个问题就是,匹配的时候这个function要执行几次呢?每一次里面的参数的值会发生什么变化呢?看例子
- //replace(RegExp,function)
- var str = "I am hainan hainan";
- console.log( str.replace(/(hainan)/g,function(){
- console.log(arguments);
- }) );
结果就是这样
这个可以看出,function执行了两遍,就是因为正则(/(hainan)/g)匹配了两遍,我们可以再验证一下,
- //replace(RegExp,function)
- var str = "I am hainan hainan";
- console.log( str.replace(/(hainan)/,function(){
- console.log(arguments);
- }) );
确实是这样吧,里面的参数时每一次匹配的结果。而我们每次替换的值就是第一个参数的值,因为第一的参数就是正则匹配的全文本嘛。
用function解决几个前面的例子吧
先看例子5那个
- //replace(RegExp,'特殊标记')
- var str = "I am hainan Allenxing";
- console.log(str.replace(/(hainan)\s*(Allenxing)/g,function(arg0,arg1,arg2){
- return arg2 + " " + arg1;
- }));
- //I am Allenxing hainan
再看例子8
- var str = "javascript";
- console.log(str.replace(/java(script)/g,function(arg0,arg1){
- return arg0 +" is " + arg1;
- }))
都是差不多的,只是用function做参数时,我们不能使用原来的正则表达式来得到匹配字符的左右的字符,需要修改正则表达式。
弄一个实际的例子,查找字符串中出现最多的字符和个数? 例如:sdjksfssscfssdd -> 字符最多的是s,出现了7次。用replace函数解决。
- var str = "sdjksfssscfssdd";
- str = str.split("").sort().join("");
- var count = 0;
- var val;
- str.replace(/(\w)\1*/g,function(arg0,arg1){
- if(arg0.length > count){
- count = arg0.length;
- val = arg1;
- }
- });
- console.log(val+" 出现了"+count+" 次");
小结
replace函数就总结到这,其实它能做好多事情,其实主要是正则表达式的功劳,正则表达式这里就不详细说了,园子里好多牛人都总结过,大家可以找找看看,想要面试的同学好好准备吧。
【javascript杂谈】你所不知道的replace函数的更多相关文章
- JavaScript中你所不知道的Object(二)--Function篇
上一篇(JavaScript中你所不知道的Object(一))说到,Object对象有大量的内部属性,而其中多数和外部属性的操作有关.最后留了个悬念,就是Boolean.Date.Number.Str ...
- JavaScript中你所不知道的Object(一)
Object实在是JavaScript中很基础的东西了,在工作中,它只有那么贫瘠的几个用法,让人感觉不过尔尔,但是我们真的了解它吗? 1. 当我们习惯用 var a = { name: 'tarol' ...
- 你所不知道的printf函数
#include <stdio.h> int main(void) { int a = 4; int b = 3; int c = a / b; float d = *(float *)( ...
- js值----你所不知道的JavaScript系列(6)
1.数组 在 JavaScript 中,数组可以容纳任何类型的值,可以是字符串.数字.对象(object),甚至是其他数组(多维数组就是通过这种方式来实现的) .----<你所不知道的JavaS ...
- js类型----你所不知道的JavaScript系列(5)
ECMAScirpt 变量有两种不同的数据类型:基本类型,引用类型.也有其他的叫法,比如原始类型和对象类型等. 1.内置类型 JavaScript 有七种内置类型: • 空值(null) • 未定义( ...
- 闭包----你所不知道的JavaScript系列(4)
一.闭包是什么? · 闭包就是可以使得函数外部的对象能够获取函数内部的信息. · 闭包是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分. · 闭包就 ...
- 你所不知道的 CSS 阴影技巧与细节 滚动视差?CSS 不在话下 神奇的选择器 :focus-within 当角色转换为面试官之后 NPOI 教程 - 3.2 打印相关设置 前端XSS相关整理 委托入门案例
你所不知道的 CSS 阴影技巧与细节 关于 CSS 阴影,之前已经有写过一篇,box-shadow 与 filter:drop-shadow 详解及奇技淫巧,介绍了一些关于 box-shadow ...
- 你所不知道的setInterval
在你所不知道的setTimeout记载了下setTimeout相关,此篇则整理了下setInterval:作为拥有广泛应用场景(定时器,轮播图,动画效果,自动滚动等等),而又充满各种不确定性的这set ...
- 你所不知道的setTimeout
JavaScript提供定时执行代码的功能,叫做定时器(timer),主要由setTimeout()和setInterval()这两个函数来完成.它们向任务队列添加定时任务.初始接触它的人都觉得好简单 ...
随机推荐
- 命令行模式 svn版本管理
linux 下svn 在命令行模式下的操作安装完svn服务并配置了环境变量之后,要创建一个存放工厂(项目)的仓库repositories用于版本控制(比如我的repositories的路径为 path ...
- hash连接
简单回顾嵌套循环: 两个表关联,较小的表(指使用了过滤条件后结果集较小的表)称为驱动表或者外表(,另一个称为内表.在嵌套连接过程中,oracle首先读取驱动表的第一条数据,然后和内表进行比对,所以匹配 ...
- Eclipse的FindBugs插件
Eclipse的FindBugs插件 问题提出: 当我们编写完代码,做完单元测试等各种测试后就提交正式运行,只能由运行的系统来检测我们代码是否有问题了,代码中隐藏的错误在系统运行的过程中被 ...
- Max Points on a Line
Given n points on a 2D plane, find the maximum number of points that lie on the same straight line. ...
- 数据分析:中国高校更名历史 Python
上周领了新任务,做国内高校改名历史的统计,这个挺有意思,以下是我任务完成过程,和大家分享. 一. 数据收集 数据需求:目前已有高校校名,各高校改名历史记录 高校校名数据来源:尝试从高校排名网站(iPI ...
- CSS应用心得
单纯Html配合CSS网页 下面用程序来实际总结一下 首先,在写程序的应该具有一个良好的编程习惯. 第一:排版,拥有一个良好的排版,有助于我们能够快速的理解以及阅读程序: 第二:注释,就如以下程序,作 ...
- 【阿迪达斯 ZX850 系列】
[阿迪达斯zx850系列 灰蓝桔 36-44] [阿迪达斯 ZX850 新配色B34720 情侣鞋 36-44] [阿迪达斯 ZX850 新配色B34720 情侣鞋 36-44] [阿迪达斯 ZX85 ...
- alibaba-dexposed 原理解析
alibaba-dexposed 原理解析 使用参考地址: http://blog.csdn.net/qxs965266509/article/details/49821413 原理参考地址: htt ...
- POSIX正则表达式
POSIX正则表达式规范 参考:http://en.wikipedia.org/wiki/Regular_expression POSIX正则表达式分为Basic Regular Expression ...
- form表单修改label样式
<?php $form = ActiveForm::begin([ 'options'=>['enctype'=>'multipart/form-data','class' => ...