jQuery.query.js 取参数的两点问题

最近在项目中使用jQuery.query.js这个插件进行页面间URL传值,遇到如下两点问题:

1. 参数中存在空格时取到的值中空格被替换为加号:+

2. 当参数某个key的value不存在时,获取到的value并不是空/null  而是true。

在网上找到了个解决方案,可以参考下(是否有其他副作用暂时未实验出)

1. 空格变加号+

在jQuery.query.js文件中找到下面代码


1

2

3

4

5

6

7

toString: function() {

           var i = 0, queryString = [], chunks = [], self = this;

           var encode = function(str) {

               str = str + "";

               //if ($spaces) str = str.replace(/ /g, "+");

               return encodeURIComponent(str);

    };

注释掉  if ($spaces) str = str.replace(/ /g, "+"); 那一行即可

2. value为空的情况


1

2

3

4

5

6

7

8

9

10

11

get: function (key)

{

    var target = this.GET(key);

    if (typeof (target) == ‘boolean‘)

        return ‘‘;

    if (is(target, Object))

        return jQuery.extend(true, {}, target);

    else if (is(target, Array))

        return target.slice(0);

    return target;

},


1

<br>


1

<div>加入  </div><p>if (typeof (target) == ‘boolean‘)                     </p><p>return ‘‘; 即可  </p>

时间: 2024-10-16 06:46:44

jQuery.query.js 取参数的两点问题的相关文章

Jquery和js取数据的区别以及引用Jquery文件

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-

jquery 、 JS 脚本参数的认识与使用

如何使用jquery刷新当前页面 下面介绍全页面刷新方法:有时候可能会用到 1 window.location.reload(); //刷新当前页面. 2 3 parent.location.reload(); //刷新父亲对象(用于框架) 4 5 opener.location.reload(); //刷新父窗口对象(用于单开窗口) 6 7 top.location.reload(); //刷新最顶端对象(用于多开窗口) 下面再介绍一些javascript基本函数 1 document.wri

jquery.query.js 插件的用法

转载自:http://www.cnblogs.com/dachie/archive/2010/09/16/1827840.html 代码如下: var url = location.search; > "?action=view&section=info&id=123&debug&testy[]=true&testy[]=false&testy[]" var section = $.query.get('section'); >

Jquery.LazyLoad.js实现图片延迟加载功能

从网上下载来的版本多多少少都有些BUG,尤其是加载后在IE6和IE7下图片闪动是个大问题,在网上查了很久,也没有找到相关的解决方案.没解决方案,就得发挥咱DIY的精神,自己想法解决,分析了BUG,理了理思路,结合前段时间我做弹出窗口特效的方法,解决了Jquery.LazyLoad.js的兼容问题,现将思路和方法与大家分享一下. 解决思路大致是两点,一是从LazyLoad本身的滤镜参数下手,发现有一个参数在IE6和IE7是可以用的,就是show,那么在IE6和IE7下用这个特效:二是IE8以上(包

ajax分页实现,jquery.pagination.js

1.前台使用ajax无刷新分页,主要需要生成分页的工具条,这里使用的是jquery.pagination.js 插件参数可以参考----张龙豪-jquery.pagination.js分页 下面贴出代码 1 /** 2 * This jQuery plugin displays pagination links inside the selected elements. 3 * 4 * @author Gabriel Birke (birke *at* d-scribe *dot* de) 5

Jquery.LazyLoad.js修正版下载,实现图片延迟加载插件

之前一直有关注过Jquery.LazyLoad.js这个特效,但一直没有用,这几天研究了一下,并应用于实际中,对网站SEO方面没有什么帮助,不过可以节省一些流量,对于大网站来说显的尤为重要,至于节省了多少流量我无从统计. 从网上下载来的版本多多少少都有些BUG,尤其是加载后在IE6和IE7下图片闪动是个大问题,在网上查了很久,也没有找到相关的解决方案.没解决方案,就得发挥咱DIY的精神,自己想法解决,分析了BUG,理了理思路,结合前段时间我做弹出窗口特效的方法,解决了Jquery.LazyLoa

一.使用jquery.datatables.js

2014年8月10日星期日 使用jquery.datatables.js取后台数据. 1.html代码 <table class="dataTables-example"> <thead> <tr> <th>id</th> <th>项目</th> <th>内容</th> <th>所属公司</th> <th>开始日期</th> <

jquery.dragsort.js 实现拖拽过程遇到的问题

1.在IE下第一次拖动的时候,被拖动的li元素会不显示,查了很多资料发现是因为在IE中定位出了问题,li标签还在,只是位置计算出错.解决的办法是在li的css样式中position设置为relative.这个问题在火狐等其他浏览器是不存在的. 2.如果拖动的li所在容器出现了滚动条,当滚动条滑到最下面的时候,拖拽下面的li的浮动层位置会出现偏移.解决的办法是在jquery.dragsort.js中,this.draggedItem.css({ top: top, left: left });这句

使用jquery.more.js来实现点击底部更多后, 底部加载出新的数据

<div class="bus-nav-bar ft12"> <div class="navt bor-r-c pos-rel {if $int == 0}fwbold{/if}"><a href="portal.php?mod=merchant&action=voucherlist&int=0">全部订单</a><em class="pos-abs">