• JS-正则表达式-替换


    利用正则表达式将源字符串中的某一部分替换成另一部分(只能替换文字字母,字符不能替换):

    var sToChange = "The sky is red";

    var result = sToChange.replace("red", "blue");

    alert(result); //输出:The sky is blue
    上面的 replace 方法第一个参数是一个字符串,第二个是要替换的部分,但这样只能替换一次.要将源字符串中所有的red都替换成blud,可以这样:

    var sToChange = "The sky is red really red";

    var reg = /red/gi

    var result = sToChange.replace(reg, "blue");

    alert(result); //输出:The sky is blue really blue
    上面第一个参数是一个正则表达式,第二个是要替换成的部分.还有另一种做法,第一个参数是正则表达式,第二个是处理函数:

    var sToChange = "The sky is red really red";

    var reg = /red/gi

    var result = sToChange.replace(reg, function(sMatch){ return "blue"; });

    alert(result); //输出:The sky is blue really blue

    上面函数里面的sMatch表示通过匹配,从源字符串中获得到的已匹配的字符.如上例中,模式从源字符串中匹配出来的始终都是"red";更直观的例子如下:

    var sTo = /(fuck|shit|ahswhole|bitch)/g;

    var sMyStr = "the son of the bitch,fuck you ,like a piece of shit!ahswhole!";

    var resultStr = sMyStr.replace(sTo, function(sMatch){ return sMatch.replace(/./g, "*"); });

    alert(resultStr); //输出:the son of the *****,**** you ,like a piece of ****!********!

    可以看出输出的星号是不等的,因为匹配的时候,当表达式匹配到bitch的时候,传入函数的就是bitch,然后函数将它替换成:*****,五个星号,然后返回;然后继续匹配,碰到fuck,然后传入函数,这时sMatch就是:fuck,然后将它替换成:****四个星号.依此类推.

     
    另一实例;
    var sToChange = document.getElementByIdx_x("abc").innerHTML;
    var reg = /<img.*?src="(.*?)".*?>/gi
    var result = sToChange.replace(reg, function(sMatch){
      var backStr = "<a href="" + RegExp.$1 + "" class="highslide" onclick="return hs.expand(this)">";
      backStr += sMatch;
      backStr += "</a>";
      backStr += "";
      return backStr;
    });
    document.getElementByIdx_x("abc").innerHTML = result;
  • 相关阅读:
    php 转化整型需要注意的地方
    生成6位随机数
    php://input
    ios常见问题 经验之谈
    ios 从前台返回到回台 从后台返回到前台 或者 支付宝支付订单后 对界面进行操作
    ios根据文本自适应 然后 搭建类似如下效果
    iosTableView 局部全部刷新以及删除编辑操作
    ios打开系统自带APP
    iOS通过URL Scheme启动app(收集了常用的app的URL Scheme)
    ios UIApplocation 中APP启动方式
  • 原文地址:https://www.cnblogs.com/xjt360/p/3552586.html
Copyright © 2020-2023  润新知