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. 前端学习 第六弹: javascript中的函数与闭包

    前端学习 第六弹:  javascript中的函数与闭包 当function里嵌套function时,内部的function可以访问外部function里的变量 function foo(x) {   ...

  2. fdisk,mount.label

    ########fdisk ll /dev/sda* df -TH fdisk -cul fdisk -cu ~~n~~p~~+1G~~ partx -a /dev/sda ########EXT4 ...

  3. [原创]cocos2d-x研习录-第三阶 多分辨率适配器

    在移动终端(智能手机)平台下开发游戏一般都会涉及到屏幕多分辨率适配问题,原因是手机款式多种多样,不同的款式存在有不同的尺寸,即使尺寸相同又可能存在不同的分辨率. 手机屏幕尺寸:指手机屏幕对角线长度. ...

  4. #uwp# XMAL

    类型转换 在xaml中对属性赋值时,会将填入的字符串转换成对应的属性类型.比如: <Button Visibility="Visible" /> 会将Visible这个 ...

  5. C#调试心经(1)(转)

    我们在做程序开发时,难免会遇到错误异常.如何快速地找到出错的地方.分析错误的原因以及找到解决问题的方案,是许多初级程序员困扰的问题,这也正是经验的宝贵之处.下面我将简单介绍在Visual Studio ...

  6. 自动化运维:flask-bootstrap + highstock整合

    1.在flask-bootstrap的base.html模板中加载highstock.js      以下是base.html的源码中,调用js文件的例子. 文件路径:python2.7/site-p ...

  7. jquery 通知页面变化

    var PageTitleNotification = { Vars: { OriginalTitle: document.title, Interval: null, IsNotificationE ...

  8. SQL:实现流水账的收入、支出、本期余额

    有多组数据,分别是收入,支出,余额,它们的关系是:本期余额=上次余额+收入-支出 /* 测试数据: Create Table tbl([日期] smalldatetime,[收入] int ,[支出] ...

  9. Markdown 软件

    <<github.css>> Markdown 软件 :Typora / Haroopad / Markdownpad2 Markdownpad2软件注册及下载地址 邮箱地址: ...

  10. <<Differential Geometry of Curves and Surfaces>>笔记

    <Differential Geometry of Curves and Surfaces> by Manfredo P. do Carmo real line Rinterval I== ...