• JS 正则查找与替换


    JS正则查找与替换

    一、前提/背景

      今天遇到个问题,需要替换字符串中部分字符,这些字符相对整个字符串而言,与其他子字符串类似,无法单独提出;重要的是,该字符串是动态的生成的,就像我们日常看到的网页Url一样,同一个页面,Url路径不总是相同,这时还需要有区别的判断。所以、这时最好的方式,就是使用JS正则表达式匹配各个部分,然后有由各个匹配的部分再组合上参数,替换原来的Url路径。至此、可解决目前我们讨论的问题。  

    贴出demo代码:  

    <script type="text/javascript" charset="utf-8">
        function changeURI(value) {
            let href = location.href;
            let pattern = /^(.+d+/d+/d+/)(d+)(/?)(.*)/;
            if (typeof value === "number") {
                if (arguments.length === 2) {
                    href = href.replace(pattern, "$1" + value + "$3$4");
                } else {
                    let result = pattern.exec(href)
                    if (result && result.length >= 3) {
                        href = href.replace(pattern, "$1" + (parseInt(result[2]) + value) + "$3$4");
                    }
                }
            } else {
                let result = pattern.exec(href)
                if (result && "" === result[3]) {
                    href = href.replace(pattern, "$1$2/" + value);
                } else {
                    href = href.replace(pattern, "$1$2$3" + value);
                }
            }
            $(location).prop("href", href);
        }
    </script>

       以上、就是我们解决JS正则匹配、替换的代码,略有不足,欢迎指正。

  • 相关阅读:
    MongoDB + Spark: 完整的大数据解决方案
    07对象字面量
    05JavaScript中数组的使用
    04JavaScript中函数也是对象
    03JavaScript中的函数预解析
    02通过arguments实现方法重载
    01函数重名问题
    mxGraph 学习笔记 --mxGraph常用功能代码
    mxGraph学习笔记--设置节点鼠标事件
    mxGraph 学习笔记 --右键菜单
  • 原文地址:https://www.cnblogs.com/julygift/p/9235066.html
Copyright © 2020-2023  润新知