关于JavaScript中string 的replace

时间:2024-05-05 09:22:42 

replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。

语法:string.replace(subStr/reg,replaceStr/function)

第一个参数可以是字符串的子字符串,也可以是一个正则表达式,第二个参数可以是一个字符串或者一个处理方法,下面我们分别看看


document.write('1234'.replace(1, 'X'));我们可以得到结果:X234,很正常,但是



document.write('1214'.replace(1, 'X'));我们预想结果应该是:X2X4,但是得到的结果却是:X214,也就是说如果我们第一个参数写的是子字符串,那么replace只替换第一个匹配就停止搜索


我们换为正则的写法


document.write('1214'.replace(/1/g, 'X'));这时候我们可以得到预想结果:X2X4


我们看看function的写法


var r = 'abcd'.replace(/\w/g, function() {
            return 'X';
        });
        document.write(r);


这时我们可以看到预想结果:XXXX,所有字符被替换为X,这是我之前对replace的认识,但我在JavaScript语言精粹上看到这样一个例子,我迷惑了


var t = document.getElementById('t');
        String.prototype.deentityfy = function() {
            var entity = {
                quot: '"',
                lt: '<',
                gt: '>'
            };
            return function() {
                return this.replace(/&([^&;]+);/g, function(a, b) {
                   var r = entity[b];
                    return typeof r === 'string' ? r : a;
                }); //end of replace
            };
        } ();

        document.write('&lt;&quot;&gt;'.deentityfy());

这段代码是为JavaScript的String对象添加一个deentityfy 方法,用以替换字符串中得HTML字符(把&quot;替换为”,&lt;替换为<,&gt;替换为>),我们先忽略作者使用的语言技巧,看看他的replace是怎么用的,第一个参数是一个正则表达式,是匹配之前提到的三个字符串,第二个参数的function竟然有了两个参数,这两个参数到底是什么?为什么方法却得到了预想结果,我们来简单分析一下。

首先entity[b]是JavaScript关联数组的用法,根据数组数据的name得到value,为了方便理解,我们不妨改造一下这个方法,让它变得简单些,让我们可以更清楚地看到function的参数到底是什么,同时为了消除浏览器转码问题,我们修改一下替换字符串


String.prototype.deentityfy = function() {
         var entity = {
             a: 'A',
             b: 'B',
             c: 'C'
         };
         return function() {
             return this.replace(/1([^12])2/g, function(a, b) {
                 for (var i = 0; i < arguments.length; i++) {
                     document.write(arguments[i] + '<br/>');
                 }
                 document.write('===========================<br/>');
                 var r = entity[b];
                 return typeof r === 'string' ? r : a;
             }); //end of replace
         };
     } ();
     document.write('1a21b21c2'.deentityfy());


这样,我们把方法的参数都打印出来,看看结果是什么


a2
a

a21b21c2
===========================
b2

 
a21b21c2
===========================
c2
c

a21b21c2
===========================
ABC


很奇怪对不对,最后的<”>是方法的结果,很正确,得到了预期结果,让我们看看function的参数部分,

function被调用了3次,恰恰是匹配的次数,每次都置换匹配字符串。

每次调用的时候方法有四个参数

第一个参数很简单,是匹配字符串

第二个很诡异,不过每个都看一遍不难得出,第二个参数是正则表达式括号内的匹配的内容

第三个参数和容易想到,是匹配项在字符串中的index

第四个参数则是原字符串

很神奇对不对,但是不是就是这样了呢,我们再写一个试试


var r = '1a21b21c2'.replace(/1\w2/g, function() {
            for (var i = 0; i < arguments.length; i++) {
                document.write(arguments[i] + '<br/>');
            }
            document.write('===========================<br/>')
            return 'X';
        });
        document.write(r);


和前面例子很像,只是简单的把所有匹配项替换为了X,看看结果


a2

a21b21c2
===========================
b2

a21b21c2
===========================
c2

a21b21c2
===========================
XXX

出乎意料对不对,结果是预期的,但是参数少了一个,第二项参数不见了,看看究竟还有什么不同——正则表达式中看似多余的括号不见了,上一个例子中,第二项参数恰恰是括号内的匹配项,是不是第二个参数就是正则表达式中括号内的匹配项呢,我们把括号加回来验证一下


var r = '1a21b21c2'.replace(/1(\w2)/g, function() {
            for (var i = 0; i < arguments.length; i++) {
                document.write(arguments[i] + '<br/>');
            }
            document.write('===========================<br/>')
            return 'X';
        });
        document.write(r);


看看结果


a2
a2

a21b21c2
===========================
b2
b2

a21b21c2
===========================
c2
c2

a21b21c2
===========================
XXX

果不其然,这样我们就了解了function中到底有哪些参数,现在看看JavaScript语言精粹重的例子就应该明白了,当然我们需要知道关联数组,立即执行函数,闭包和arguments对象,如果让我们把一句话中所有的单词首字母大写,是不是会了呢


//方法很多,这个只是验证我们刚才的理论才故意写成这样麻烦的做法
 var sentence = 'i love you';
        var upper = sentence.replace(/(\w)\w*\b/g, function(a,b) {
            return b.toUpperCase()+a.substring(1);
        });
        document.write(upper);



//这样写其实已经可以胜任
  var sentence = 'i love you';
        var upper = sentence.replace(/\w+\b/g, function(a) {
            return a.substr(0,1).toUpperCase()+a.substring(1);
        });
        document.write(upper);

标签:javascript,replace,string
0
投稿

猜你喜欢

  • Python实现微信中找回好友、群聊用户撤回的消息功能示例

    2022-02-04 02:51:02
  • JSP实现客户信息管理系统

    2023-06-30 05:32:36
  • Python编程中使用Pillow来处理图像的基础教程

    2021-07-20 10:53:19
  • Python数据结构详细

    2022-10-03 21:02:00
  • Python可变与不可变数据和深拷贝与浅拷贝

    2022-06-05 21:14:51
  • Python利用物理引擎Pymunk编写一个解压小游戏

    2022-03-08 16:15:45
  • MSSQL2000安全设置图文教程

    2024-01-13 22:16:35
  • tensorflow -gpu安装方法(不用自己装cuda,cdnn)

    2021-01-26 09:06:46
  • Python正则替换字符串函数re.sub用法示例

    2021-03-04 17:25:42
  • 详解JavaScript基于面向对象之继承

    2024-04-29 13:23:06
  • Python常用的文件及文件路径、目录操作方法汇总介绍

    2022-03-21 00:00:25
  • Python深度学习之FastText实现文本分类详解

    2022-09-03 10:35:28
  • 详解Python Flask API 示例演示(附cookies和session)

    2021-12-03 18:37:29
  • python抓取最新博客内容并生成Rss

    2022-06-18 08:38:40
  • 关于Keras模型可视化教程及关键问题的解决

    2021-03-19 10:39:07
  • Python监听键盘和鼠标事件的示例代码

    2022-06-14 07:05:23
  • python数据清洗系列之字符串处理详解

    2023-08-02 04:00:07
  • jquery和css3中的选择器nth-child使用方法和用途示例

    2024-04-25 13:11:35
  • Python 内置函数速查表一览

    2021-10-30 07:43:06
  • IDEA连接不上MySQL端口号占用的解决

    2024-01-24 14:49:21
  • asp之家 网络编程 m.aspxhome.com