zoukankan      html  css  js  c++  java
  • JQuery获取URL

      如果习惯了URL传参,那获取URL参数是难免的,在查询或者排序的时候用到URL传参是很普遍的事情,既然有需要用URL参数传参,那么获取URL参数就成必须的了,没人希望,在第6页的时候点了下排序,结果回到第一页去了..

      JQuery日益盛行的今天,我们在写JS的时候,第一时间想到的可能就是如何通过JQuery来解决我们的需求。今天这里提供一个我常用的JQuery获取URL的代码,大家可以自己做成个JQuery插件。

    new function(settings) {
    var $separator = settings.separator || '&';
    var $spaces = settings.spaces === false ? false : true;
    var $suffix = settings.suffix === false ? '' : '[]';
    var $prefix = settings.prefix === false ? false : true;
    var $hash = $prefix ? settings.hash === true ? "#" : "?" : "";
    var $numbers = settings.numbers === false ? false : true;

    jQuery.query = new function() {
    var is = function(o, t) {
    return o != undefined && o !== null && (!!t ? o.constructor == t : true);
    };
    var parse = function(path) {
    var m, rx = /\[([^[]*)\]/g, match = /^([^[]+)(\[.*\])?$/.exec(path), base = match[1], tokens = [];
    while (m = rx.exec(match[2])) tokens.push(m[1]);
    return [base, tokens];
    };
    var set = function(target, tokens, value) {
    var o, token = tokens.shift();
    if (typeof target != 'object') target = null;
    if (token === "") {
    if (!target) target = [];
    if (is(target, Array)) {
    target.push(tokens.length == 0 ? value : set(null, tokens.slice(0), value));
    } else if (is(target, Object)) {
    var i = 0;
    while (target[i++] != null);
    target[--i] = tokens.length == 0 ? value : set(target[i], tokens.slice(0), value);
    } else {
    target = [];
    target.push(tokens.length == 0 ? value : set(null, tokens.slice(0), value));
    }
    } else if (token && token.match(/^\s*[0-9]+\s*$/)) {
    var index = parseInt(token, 10);
    if (!target) target = [];
    target[index] = tokens.length == 0 ? value : set(target[index], tokens.slice(0), value);
    } else if (token) {
    var index = token.replace(/^\s*|\s*$/g, "");
    if (!target) target = {};
    if (is(target, Array)) {
    var temp = {};
    for (var i = 0; i < target.length; ++i) {
    temp[i] = target[i];
    }
    target = temp;
    }
    target[index] = tokens.length == 0 ? value : set(target[index], tokens.slice(0), value);
    } else {
    return value;
    }
    return target;
    };

    var queryObject = function(a) {
    var self = this;
    self.keys = {};

    if (a.queryObject) {
    jQuery.each(a.get(), function(key, val) {
    self.SET(key, val);
    });
    } else {
    jQuery.each(arguments, function() {
    var q = "" + this;
    q = q.replace(/^[?#]/, '');
    q = q.replace(/[;&]$/, '');
    if ($spaces) q = q.replace(/[+]/g, ' ');

    jQuery.each(q.split(/[&;]/), function() {
    var key = decodeURIComponent(this.split('=')[0] || "");
    var val = decodeURIComponent(this.split('=')[1] || "");

    if (!key) return;

    if ($numbers) {
    if (/^[+-]?[0-9]+\.[0-9]*$/.test(val))
    val = parseFloat(val);
    else if (/^[+-]?[0-9]+$/.test(val))
    val = parseInt(val, 10);
    }

    val = (!val && val !== 0) ? true : val;

    if (val !== false && val !== true && typeof val != 'number')
    val = val;

    self.SET(key, val);
    });
    });
    }
    return self;
    };

    queryObject.prototype = {
    queryObject: true,
    has: function(key, type) {
    var value = this.get(key);
    return is(value, type);
    },
    GET: function(key) {
    if (!is(key)) return this.keys;
    var parsed = parse(key), base = parsed[0], tokens = parsed[1];
    var target = this.keys[base];
    while (target != null && tokens.length != 0) {
    target = target[tokens.shift()];
    }
    return typeof target == 'number' ? target : target || "";
    },
    get: function(key) {
    var target = this.GET(key);
    if (is(target, Object))
    return jQuery.extend(true, {}, target);
    else if (is(target, Array))
    return target.slice(0);
    return target;
    },
    SET: function(key, val) {
    var value = !is(val) ? null : val;
    var parsed = parse(key), base = parsed[0], tokens = parsed[1];
    var target = this.keys[base];
    this.keys[base] = set(target, tokens.slice(0), value);
    return this;
    },
    set: function(key, val) {
    return this.copy().SET(key, val);
    },
    REMOVE: function(key) {
    return this.SET(key, null).COMPACT();
    },
    remove: function(key) {
    return this.copy().REMOVE(key);
    },
    EMPTY: function() {
    var self = this;
    jQuery.each(self.keys, function(key, value) {
    delete self.keys[key];
    });
    return self;
    },
    load: function(url) {
    var hash = url.replace(/^.*?[#](.+?)(?:\?.+)?$/, "$1");
    var search = url.replace(/^.*?[?](.+?)(?:#.+)?$/, "$1");
    return new queryObject(url.length == search.length ? '' : search, url.length == hash.length ? '' : hash);
    },
    empty: function() {
    return this.copy().EMPTY();
    },
    copy: function() {
    return new queryObject(this);
    },
    COMPACT: function() {
    function build(orig) {
    var obj = typeof orig == "object" ? is(orig, Array) ? [] : {} : orig;
    if (typeof orig == 'object') {
    function add(o, key, value) {
    if (is(o, Array))
    o.push(value);
    else
    o[key] = value;
    }
    jQuery.each(orig, function(key, value) {
    if (!is(value)) return true;
    add(obj, key, build(value));
    });
    }
    return obj;
    }
    this.keys = build(this.keys);
    return this;
    },
    compact: function() {
    return this.copy().COMPACT();
    },
    toString: function() {
    var i = 0, queryString = [], chunks = [], self = this;
    var encode = function(str) {
    str = str + "";
    if ($spaces) str = str.replace(/ /g, "+");
    return encodeURIComponent(str);
    };
    var addFields = function(arr, key, value) {
    if (!is(value) || value === false) return;
    var o = [encode(key)];
    if (value !== true) {
    o.push("=");
    o.push(encode(value));
    }
    arr.push(o.join(""));
    };
    var build = function(obj, base) {
    var newKey = function(key) {
    return !base || base == "" ? [key].join("") : [base, "[", key, "]"].join("");
    };
    jQuery.each(obj, function(key, value) {
    if (typeof value == 'object')
    build(value, newKey(key));
    else
    addFields(chunks, newKey(key), value);
    });
    };

    build(this.keys);

    if (chunks.length > 0) queryString.push($hash);
    queryString.push(chunks.join($separator));

    return queryString.join("");
    }
    };

    return new queryObject(location.search, location.hash);
    };
    } (jQuery.query || {});

         获取是直接用:

    获取URL参数

    function SelChange() {
    var s
    = $.query.get('state');
    var p
    = $.query.get('page');
    var o
    = $("#selOrder").val();
    var url
    = "Student.aspx";
    if (o + "$" != "$") {
    url
    += "?od=" + o;
    if (s + "$" != "$") {
    url
    += "&state="+s;
    }
    if (p + "$" != "$") {
    url
    += "&page="+p;
    }
    window.location.href
    = url;
    }

    }
    new function(settings) {
        var $separator = settings.separator || '&';
        var $spaces = settings.spaces === false ? false : true;
        var $suffix = settings.suffix === false ? '' : '[]';
        var $prefix = settings.prefix === false ? false : true;
        var $hash = $prefix ? settings.hash === true ? "#" : "?" : "";
        var $numbers = settings.numbers === false ? false : true;

        jQuery.query = new function() {
            var is = function(o, t) {
                return o != undefined && o !== null && (!!t ? o.constructor == t : true);
            };
            var parse = function(path) {
                var m, rx = /\[([^[]*)\]/g, match = /^([^[]+)(\[.*\])?$/.exec(path), base = match[1], tokens = [];
                while (m = rx.exec(match[2])) tokens.push(m[1]);
                return [base, tokens];
            };
            var set = function(target, tokens, value) {
                var o, token = tokens.shift();
                if (typeof target != 'object') target = null;
                if (token === "") {
                    if (!target) target = [];
                    if (is(target, Array)) {
                        target.push(tokens.length == 0 ? value : set(null, tokens.slice(0), value));
                    } else if (is(target, Object)) {
                        var i = 0;
                        while (target[i++] != null);
                        target[--i] = tokens.length == 0 ? value : set(target[i], tokens.slice(0), value);
                    } else {
                        target = [];
                        target.push(tokens.length == 0 ? value : set(null, tokens.slice(0), value));
                    }
                } else if (token && token.match(/^\s*[0-9]+\s*$/)) {
                    var index = parseInt(token, 10);
                    if (!target) target = [];
                    target[index] = tokens.length == 0 ? value : set(target[index], tokens.slice(0), value);
                } else if (token) {
                    var index = token.replace(/^\s*|\s*$/g, "");
                    if (!target) target = {};
                    if (is(target, Array)) {
                        var temp = {};
                        for (var i = 0; i < target.length; ++i) {
                            temp[i] = target[i];
                        }
                        target = temp;
                    }
                    target[index] = tokens.length == 0 ? value : set(target[index], tokens.slice(0), value);
                } else {
                    return value;
                }
                return target;
            };

            var queryObject = function(a) {
                var self = this;
                self.keys = {};

                if (a.queryObject) {
                    jQuery.each(a.get(), function(key, val) {
                        self.SET(key, val);
                    });
                } else {
                    jQuery.each(arguments, function() {
                        var q = "" + this;
                        q = q.replace(/^[?#]/, '');
                        q = q.replace(/[;&]$/, '');
                        if ($spaces) q = q.replace(/[+]/g, ' ');

                        jQuery.each(q.split(/[&;]/), function() {
                            var key = decodeURIComponent(this.split('=')[0] || "");
                            var val = decodeURIComponent(this.split('=')[1] || "");

                            if (!key) return;

                            if ($numbers) {
                                if (/^[+-]?[0-9]+\.[0-9]*$/.test(val))
                                    val = parseFloat(val);
                                else if (/^[+-]?[0-9]+$/.test(val))
                                    val = parseInt(val, 10);
                            }

                            val = (!val && val !== 0) ? true : val;

                            if (val !== false && val !== true && typeof val != 'number')
                                val = val;

                            self.SET(key, val);
                        });
                    });
                }
                return self;
            };

            queryObject.prototype = {
                queryObject: true,
                has: function(key, type) {
                    var value = this.get(key);
                    return is(value, type);
                },
                GET: function(key) {
                    if (!is(key)) return this.keys;
                    var parsed = parse(key), base = parsed[0], tokens = parsed[1];
                    var target = this.keys[base];
                    while (target != null && tokens.length != 0) {
                        target = target[tokens.shift()];
                    }
                    return typeof target == 'number' ? target : target || "";
                },
                get: function(key) {
                    var target = this.GET(key);
                    if (is(target, Object))
                        return jQuery.extend(true, {}, target);
                    else if (is(target, Array))
                        return target.slice(0);
                    return target;
                },
                SET: function(key, val) {
                    var value = !is(val) ? null : val;
                    var parsed = parse(key), base = parsed[0], tokens = parsed[1];
                    var target = this.keys[base];
                    this.keys[base] = set(target, tokens.slice(0), value);
                    return this;
                },
                set: function(key, val) {
                    return this.copy().SET(key, val);
                },
                REMOVE: function(key) {
                    return this.SET(key, null).COMPACT();
                },
                remove: function(key) {
                    return this.copy().REMOVE(key);
                },
                EMPTY: function() {
                    var self = this;
                    jQuery.each(self.keys, function(key, value) {
                        delete self.keys[key];
                    });
                    return self;
                },
                load: function(url) {
                    var hash = url.replace(/^.*?[#](.+?)(?:\?.+)?$/, "$1");
                    var search = url.replace(/^.*?[?](.+?)(?:#.+)?$/, "$1");
                    return new queryObject(url.length == search.length ? '' : search, url.length == hash.length ? '' : hash);
                },
                empty: function() {
                    return this.copy().EMPTY();
                },
                copy: function() {
                    return new queryObject(this);
                },
                COMPACT: function() {
                    function build(orig) {
                        var obj = typeof orig == "object" ? is(orig, Array) ? [] : {} : orig;
                        if (typeof orig == 'object') {
                            function add(o, key, value) {
                                if (is(o, Array))
                                    o.push(value);
                                else
                                    o[key] = value;
                            }
                            jQuery.each(orig, function(key, value) {
                                if (!is(value)) return true;
                                add(obj, key, build(value));
                            });
                        }
                        return obj;
                    }
                    this.keys = build(this.keys);
                    return this;
                },
                compact: function() {
                    return this.copy().COMPACT();
                },
                toString: function() {
                    var i = 0, queryString = [], chunks = [], self = this;
                    var encode = function(str) {
                        str = str + "";
                        if ($spaces) str = str.replace(/ /g, "+");
                        return encodeURIComponent(str);
                    };
                    var addFields = function(arr, key, value) {
                        if (!is(value) || value === false) return;
                        var o = [encode(key)];
                        if (value !== true) {
                            o.push("=");
                            o.push(encode(value));
                        }
                        arr.push(o.join(""));
                    };
                    var build = function(obj, base) {
                        var newKey = function(key) {
                            return !base || base == "" ? [key].join("") : [base, "[", key, "]"].join("");
                        };
                        jQuery.each(obj, function(key, value) {
                            if (typeof value == 'object')
                                build(value, newKey(key));
                            else
                                addFields(chunks, newKey(key), value);
                        });
                    };

                    build(this.keys);

                    if (chunks.length > 0) queryString.push($hash);
                    queryString.push(chunks.join($separator));

                    return queryString.join("");
                }
            };

            return new queryObject(location.search, location.hash);
        };
    } (jQuery.query || {});
  • 相关阅读:
    从 0 → 1,学习Linux该这么开始!
    Web和移动开发的未来
    css-div中文字过多(内容超出div宽度)后自动换行
    js+css--单选按钮,自定义选中的颜色???(性别按钮,男女)
    css-按钮中有图片和文字,怎么才能让文字和图片都中??
    js-点出弹框后(除了点击窗口上的叉子),点其他地方能够关闭窗口???
    css-外面元素的高度,由里面的元素进行撑开(由内部的高度决定)
    js-将传来的数据排序,让(全部)这个小按钮小圈圈,始终排列在最前面
    echart--如何在折线图上添加矩形背景(可以借用bar柱状图的实现效果)
    echart-如何将x轴和y轴的原点进行重合???
  • 原文地址:https://www.cnblogs.com/_fyz/p/JqueryUrl.html
Copyright © 2011-2022 走看看