使用jQuery读取查询字符串参数返回null

时间:2010-01-15 13:37:25

标签: javascript jquery flex jquery-plugins

我正在尝试通过jQuery和查询插件读取查询字符串参数(“ssip”),但它似乎返回null而不是实际值。

这是我的代码:

<script src="jquery-1.3.2.min.js" language="javascript"></script>
<script src="jquery.query-2.7.1.js" language="javascript"></script>

<script language="JavaScript" type="text/javascript">
  function getStreamingServerIP() {
    return $.query.get('ssip');
  }
</script>

我通过ExternalInterface从Flex调用此方法。

有没有人发现上述代码存在任何问题?

3 个答案:

答案 0 :(得分:1)

我遇到了同样的问题。

我相信查询插件版本2.1.7仅与jQuery 1.2.x兼容。

在插件下载页面上,查看API版本选择框,单击“应用”,您将看到没有针对jQuery 1.3或1.4的版本。

答案 1 :(得分:0)

我在没有任何问题的情况下复制了这个网址:

http://localhost/test/test/Test.html?ssip=foo

从Firebug控制台启动的getStreamingServerIP()返回“foo”

确保您针对有效的URL而不是浏览器中加载的本地文件发出请求。

如果您有&gt;中的某些内容,请检查Firebug DOM面板&gt;然后在树视图中:

窗口&gt;位置&gt;搜索

答案 2 :(得分:0)

这就是我使用的。

<!doctype html>
<html>
<head>
<script src="jquery-1.4.js"></script>
<script>
/**
 * @return null if param not found
 * @return string if param found once
 * @return array if param found more than once or name ends with "[]"
 */
function getQueryStringParam (name) {
    var result = null;
    if (location.search !== "") {
        var querystring = location.search.substring(1).replace(/\+/g, " ");
        var pairs = querystring.split("&");
        var isFound = false;
        for (var i=0; i<pairs.length; i++) {
            var pair = pairs[i].split("=");
            var key = decodeURIComponent(pair[0]);
            if (key === name) {
                var val = (pair.length === 2 ? decodeURIComponent(pair[1]) : key);
                if (!isFound) {
                    isFound = true;
                    result = [val];
                }
                else {
                    result.push(val);
                }
            }
        }
        if (isFound && result.length == 1 && !/\[.*\]$/.test(name)){
            result = result[0];
        }
    }
    return result;
}
/**
 * helper function
 */
function printQueryStringParam (name) {
    var result = "";
    var val = getQueryStringParam(name);
    if (val === null) {
        result = "null";
    }
    else if (jQuery.isArray(val)) {
        result = "[\n\t" + val.join(",\n\t") + "\n]";
    }
    else {
        result = val;
    }
    return result;
}
</script>
</head>
<body>

<form action="test.html" method="get">
<p>
text <input type="text" name="text" 
value="space: , plus:+, slash:/, backslash:\, amp:&amp;, equals:=, less:<, greater:>"><br>
</p>
<p>
checkbox[]<br>
<input type="checkbox" name="checkbox[]" value="a" checked> a<br>
<input type="checkbox" name="checkbox[]" value="b" checked> b<br>
</p>
<p>
<input type="submit">
</p>
</form>

<hr>

<pre>
<script>
document.write("text: "+printQueryStringParam("text"));
document.write("\ncheckbox[]: "+printQueryStringParam("checkbox[]"));
</script>
</pre>

</body>
</html>