js操作浏览器Url

1.获取url中的参数

  function getUrlParam(name) {
   var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"); //构造一个含有目标参数的正则表达式对象
   var r = window.location.search.substr(1).match(reg); //匹配目标参数
   if (r != null) return decodeURI(r[2]); return null; //返回参数值
  }

2.在指定url栏附加参数或替换参数值

function urlAppendParaIndexUrl(paraName,paraValue,currentUrl){
    currentUrl=decodeURI(currentUrl);
    var urlLastWord=currentUrl.substr(-1);
    var newUrl=currentUrl//要返回的结果
    if (currentUrl.indexOf("?")<0){
    //说明没有参数
    newUrl+="?"+paraName+"="+paraValue;
    }else if(urlLastWord=="#"){
    //说明有个#
    newUrl=currentUrl.replace("#","?"+paraName+"="+paraValue);
    }else{
    //说明有参数
    var isHave=getUrlParam(paraName)
    if(isHave==null){
    //说明当前url没有要添加的参数类型
    newUrl+="&"+paraName+"="+paraValue;
    }else{
    //说明当前url有要添加的参数类型,不能附加,要替换
    newUrl=newUrl.replace(paraName+"="+isHave,paraName+"="+paraValue);
    }
    
    }
    return newUrl;
    }

3.删除Url中的指定参数

function urlDelpara(paraName,url){
    regExp=new RegExp(paraName+"=.+?&");//正则表达式加?表明使用非贪心模式
    result=url.replace(regExp,"");
    r=new RegExp("&"+paraName+"=.+");//这是考虑该参数再最后面的情况
    result=result.replace(r,"");
    r=new RegExp(paraName+"=.+");//这是考虑只有一个参数的情况
    result=result.replace(r,"");
    if(result.indexOf("?")==(result.length-1)){
    //如果最后一个是?
        result=result.replace("?","");
    }
    return result;
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,079评论 19 139
  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 4,499评论 0 5
  • 点击查看原文 Web SDK 开发手册 SDK 概述 网易云信 SDK 为 Web 应用提供一个完善的 IM 系统...
    layjoy阅读 13,987评论 0 15
  • Spring Web MVC Spring Web MVC 是包含在 Spring 框架中的 Web 框架,建立于...
    Hsinwong阅读 22,604评论 1 92
  • 亲爱的宝贝,今天外出妈妈让你帮助我好几件事,比如1问阿姨去那打包盒,2自己拿着钱去定牛肉面,3问阿姨哪里有调料等等...
    的魅力阅读 152评论 0 0