js之正则表达式初步探索

      这是我们新项目中的一个需求,在页面的顶上动态显示用户的位置。这是一个常见的需求,并没有什么新鲜的,我要说的是在其中用到的一段JS代码。用户当前位置是一个字符串,在用户当前页面作为参数获取,获取到的字符串样式如:[资产管理][固定资产管理][资产清理]。这个并不是我们需要的最终形式,我们需要将其转换成如下形式:<li><a><span>资产管理</span></a></li><li><a><span>固定资产管理</span></a></li><li><a><span class="current">资产清理</span></a></li>。

      对这个需求,我的思路是:第一步,把最后一个‘[’替换成:<span class="current"> 。我们很容易想到的是用JS中的replace方法,但是replace只能替换字符串中第一个匹配的。没关系,我们先不考虑replace,我们自己写一个方法来替换最后一个匹配的内容。

      方法一:

      //替换最后一个匹配的内容,str1 要替换的内容,str2 要替换的目标内容
    function replaceLast(contain,str1,str2){
        var index=contain.lastIndexOf(str1);
        var subStr1=contain.substring(0,index);
        var subStr2=contain.substring(index+str1.length,contain.length);
        contain=subStr1+str2+subStr2;
        return contain;

    }

      OK,问题搞定了。现在我们想想,真的不能用replace方法吗?当然是可以的,没错,和正则表达式配合。

     方法二:

     function replaceLast(contain){  
        return contain.replace(//[([^/[]*)$/,'<li><a><span class="current">$1');
     }

     里面的正则表达式貌似还比较复杂,简单介绍一下。/[表示你要替换的内容,/是转意字符。[^/[]表示除了[之外的任何字符。*表示出现0次、1次或者n次。$/表示在字符串的末尾匹配。<li><a><span class="current">$1表示把匹配的部分替换成:<li><a><span class="current">。

      第二步是把所有的‘[’替换成:<li><a><span>,所有的‘[’替换成:</span></a></li>。这个就比较简单了,还是用replace和正则表达式。

      function replaceAll(contain){
           return contain.replace(//[/g,'<li><a><span>').replace(//]/g,'</span></a></li>');
      }

      这个相对就简单很多了,说一下/g,表示全部替换。

      到此,功能就实现了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript正则表达式和Java正则表达式在语法上有一些差异,但是它们的基本概念和用法是相似的。下面是将JavaScript正则表达式转换为Java正则表达式的一些常见规则: 1. 语法差异: - JavaScript正则表达式使用斜杠(/)作为定界符,而Java正则表达式使用双引号(")作为定界符。 - JavaScript正则表达式中的特殊字符需要进行转义,而Java正则表达式中的特殊字符不需要转义。 2. 字符类: - JavaScript正则表达式中的字符类使用方括号([])表示,而Java正则表达式中使用方括号([])或者Unicode转义(\p{...})表示。 - JavaScript正则表达式中的字符类可以使用连字符(-)表示范围,而Java正则表达式中需要使用Unicode转义(\uXXXX)表示范围。 3. 量词: - JavaScript正则表达式中的量词使用花括号({})表示,而Java正则表达式中使用花括号({})或者问号(?)表示。 - JavaScript正则表达式中的贪婪量词默认是贪婪模式,而Java正则表达式中的贪婪量词需要在后面添加问号(?)来表示非贪婪模式。 4. 边界匹配: - JavaScript正则表达式中的边界匹配使用插入符号(^)和美元符号($)表示,而Java正则表达式中使用\A和\Z表示。 5. 其他差异: - JavaScript正则表达式中的捕获组使用圆括号(())表示,而Java正则表达式中使用圆括号(())或者方括号([])表示。 - JavaScript正则表达式中的反向引用使用反斜杠加数字(\1、\2等)表示,而Java正则表达式中使用美元符号加数字($1、$2等)表示。 以上是一些常见的JavaScript正则表达式转换为Java正则表达式的规则。具体转换时,还需要根据具体的正则表达式进行适当的调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值