var UrlArgent = {
Parsed: false, //是否已解析
Cache: {}, //缓存值
ParseArg: function () {
// 解析地址栏的参数值
UrlArgent.Parsed = true;
var url = location.search;
if (-1 == url.indexOf('?')) return; var args = url.substr(1).split("&");
for (var i = 0; i < args.length; i++) {
var tmp = args[i];
var pos = tmp.indexOf('=');
if (-1 == pos) continue;
UrlArgent.Cache[tmp.substr(0, pos)] = tmp.substr(pos + 1);
}
},
GetItem: function (queryStringName, defaultVal) {
// 获取单个项目的值 queryStringName大小写敏感,及区分大小写
if (UrlArgent.Parsed == false) UrlArgent.ParseArg(); return UrlArgent.Cache[queryStringName] || (typeof (defaultVal) == 'undefined' ? '' : defaultVal.toString());
},
GetItemIgnore: function (queryStringName, defaultVal) {
// 获取单个项目的值 queryStringName忽略大小写
if (UrlArgent.Parsed == false) UrlArgent.ParseArg(); for (var k in UrlArgent.Cache) {
if (UrlArgent.Cache.hasOwnProperty(k) == false) continue; //只取私有属性
if (k.toLowerCase() == queryStringName.toLowerCase()) return UrlArgent.Cache[k];
} return (typeof (defaultVal) == 'undefined' ? '' : defaultVal.toString());
},
GetUrl: function (newValue, ignore) {
// 获取url参数 newValue增加或修改的值 ignore关键字是否忽略大小写,true忽略大小写其他值大小写敏感
if (typeof (newValue) != 'object') return location.search.substr(1); //原样返回 if (UrlArgent.Parsed == false) UrlArgent.ParseArg(); var url = [];
for (var k in UrlArgent.Cache) {
if (UrlArgent.Cache.hasOwnProperty(k) == false) continue; //只取私有属性 var val = UrlArgent.Cache[k]; //默认是原值
for (var n in newValue) {
if (newValue.hasOwnProperty(n) == false) continue; if ((k == n) || (ignore == true && k.toLowerCase() == n.toLowerCase())) { //需要替换原来的值
val = newValue[n].toString(); //赋新值
newValue[n] = null; //清除设置了值的项
}
}
url.push(k + '=' + val);
} for (var n in newValue) { //新增加的键值
if (newValue.hasOwnProperty(n) == false) continue;
if (newValue[n] == null) continue;
url.push(n + '=' + newValue[n].toString());
} return url.join('&');
} };

使用:

        var a = UrlArgent.GetItem('x');
var x = UrlArgent.GetItem('x', 0);
var y = UrlArgent.GetItemIgnore('X');
var s = UrlArgent.GetUrl();
var w = UrlArgent.GetUrl({ "x": "vv", "ismobilE": "vs" });
var z = UrlArgent.GetUrl({ "X": "vv", "ismobilE": "vs" }, true);

js处理url参数的更多相关文章

  1. js获取url参数的方法

    js获取url参数的方法有很多. 1.正则分析 function getQueryString(name) { var reg = new RegExp("(^|&)" + ...

  2. get方法与post方法的区别与js获取url参数的方式

    1.get方法与post方法的区别: 区别一:get重点在从服务器上获取资源,post重点在向服务器发送数据:区别二:get传输数据是通过URL请求,以field(字段)= value的形式,置于UR ...

  3. js获取url参数,操作url参数

    function getParam(key) { var tmp = location.search; tmp = decodeURIComponent(tmp); var index = tmp.i ...

  4. js javascript 获取url,获得当前页面的url,静态html文件js读取url参数

    获得当前页面的url window.location.href 静态html文件js读取url参数 location.search; //获取url中"?"符后的字串 下边为转载的 ...

  5. js截取url参数

    举例说明,比如http://localhost:2019/blog/getCommentListInfo?postId=1如何获取postId=1这个参数值呢?很简单通过下面代码即可获取,如: win ...

  6. .NET手记-JS获取Url参数

    最近为App做活动专区,其中很多活动都是采用html 5页面来制作的.一方面体量较小,制作快速,更新维护容易:另一方面,嵌入App后适配效果也不会很差. 这里我们采用混编形式来从native app传 ...

  7. js修改url参数,无刷新更换页面url

    一.js修改地址栏URL参数 function changeURLPar(destiny, par, par_value) { var pattern = par + '=([^&]*)'; ...

  8. js 处理url参数,应用导航分类

    1.先上图 2.代码 html <li><a href="javascript:void(0);" data-cid = "{$v['id']}&quo ...

  9. JS解析URL参数为对象

    曲不离口,拳不离手 JS小编程练习之一:解析URL参数为对象 url:http://www.baidu.com/we/index.html?id=098&aaa=123&ccc=456 ...

  10. js 获取url参数的值

    //获取url参数函数function GetQueryString(name){    var reg = new RegExp("(^|&)"+ name +" ...

随机推荐

  1. 自定义响应结构 Json格式转换 工具类

    import java.util.List; import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterx ...

  2. WaitForMultipleObjects返回失败原因之一

    上网搜了下 关于 WaitForMultipleObjects等待多个线程退出的状态失败的情况,也有人遇到类似的情况. 一次项目中我也遇到这么个情况.项目中创建线程都是用的  _beginthread ...

  3. 基于日志数据分析以防御CC攻击的想法

    1. What - 什么是CC攻击 CC攻击,即针对应用层HTTP协议的DDos攻击,攻击者在短时间内向目标服务器发送大量的HTTP请求,使得服务器会非常繁忙,资源消耗会增加:同时,如果请求中包含基于 ...

  4. Hibernate的save()和persist()的区别

    hibernate之所以提供与save()功能几乎完全类似的persist()方法,一方面是为了照顾JPA的用法习惯.另一方面,save()和 persist()方法还有一个区别:使用 save() ...

  5. linux memory

    http://duartes.org/gustavo/blog/post/how-the-kernel-manages-your-memory/ http://duartes.org/gustavo/ ...

  6. oracle数据库从入门到精通之三

    综合案例ddl&dml有一个商品数据库1.数据表的创建    ddl先编写数据库脚本--删除数据表drop table purcase purge;drop table product pur ...

  7. python-print

    %s,%d就是占位符.还有%r 只是说明这样的对应:%s-->str();%r-->repr(),什么意思呢?就是说%s调用的是str()函数把对象转化为str类型,而%r是调用了repr ...

  8. jquery循环操作

    each遍历 用法一. <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...

  9. 浅入浅出EmguCv(一)OpenCv与EmguCv

    最近接触计算机视觉方面的东西,于是准备下手学习opencv,从官网下载windows的安装版,配置环境,一系列步骤走完后,准备按照惯例弄个HelloWord.也就是按照网上的教程,打开了那个图像处理领 ...

  10. Python与PHP通过XMLRPC进行通信

    Python与PHP通过XMLRPC进行通信:服务器端用Python,客户端用PHP. 服务器端:xmlrpc_server.py #!/usr/bin/python # coding: UTF-8 ...