Javascript 获取连接(url)参数的方法

qa项目可能须要客户端获取到url的参数,搜到一个很好的解决方法,记录在博客,免得之后找麻烦。javascript

方法一:分解连接的方式html

<script type="text/javascript">
/*
 * 说明:Javascript 获取连接(url)参数的方法
 */
function getQueryString(name)
{
    // 若是连接没有参数,或者连接中不存在咱们要获取的参数,直接返回空
    if(location.href.indexOf("?")==-1 || location.href.indexOf(name+'=')==-1)
    {
        return '';
    }
 
    // 获取连接中参数部分
    var queryString = location.href.substring(location.href.indexOf("?")+1);
 
    // 分离参数对 ?key=value&key2=value2
    var parameters = queryString.split("&");
 
    var pos, paraName, paraValue;
    for(var i=0; i<parameters.length; i++)
    {
        // 获取等号位置
        pos = parameters[i].indexOf('=');
        if(pos == -1) { continue; }
 
        // 获取name 和 value
        paraName = parameters[i].substring(0, pos);
        paraValue = parameters[i].substring(pos + 1);
 
        // 若是查询的name等于当前name,就返回当前值,同时,将连接中的+号还原成空格
        if(paraName == name)
        {
            return unescape(paraValue.replace(/\+/g, " "));
        }
    }
    return '';
};
 
//http://localhost/test.html?aa=bb&test=cc+dd&ee=ff
alert(getQueryString('test'));
</script>

 

方法二:用正则匹配java

<script type="text/javascript">
function getQueryStringRegExp(name)
{
    var reg = new RegExp("(^|\\?|&)"+ name +"=([^&]*)(\\s|&|$)", "i"); 
    if (reg.test(location.href)) return unescape(RegExp.$2.replace(/\+/g, " ")); return "";
};
 
//http://localhost/test.html?aa=bb&test=cc+dd&ee=ff
alert(getQueryStringRegExp('test'));
</script>

 

原文连接:http://www.codebit.cn/javascript/javascript-get-url-parameter.htmlurl

相关文章
相关标签/搜索