2

我现在的网址是:www.mysite.com/index.php?user=123

我单击链接以激活要打开的 ajax 页面。ajax 页面包含以下内容:

$usernum = $_GET["user"];
$result = mysql_query("SELECT * FROM Persons WHERE user = $usernum");

这会产生一个错误:

Warning: mysql_fetch_array() expects parameter 1 to be resource, boolean given in C:\Program Files (x86)\Ampps\www\social2\profile\indexBasics.php on line 29

如果我在用户编号中硬编码,则不会发生错误,它只是拒绝获取地址栏变量。

帮助?建议?

----- 添加信息 ------

<script>
window.onload = function () {
    var basics = document.getElementById('basics'),
        favorites = document.getElementById('favorites');

    basics.onclick = function() {
        loadXMLDoc('indexBasics');
        var otherClasses = favorites.className;
        if (otherClasses.contains("Active")) {
            basics.className = 'statusOptionActive';
            favorites.className = 'statusOption';
        }
    }

    favorites.onclick = function() {
        loadXMLDoc('indexFav');        
        var otherClasses = basics.className;
        if (otherClasses.contains("Active")) {
            favorites.className = 'statusOptionActive';
            basics.className = 'statusOption';
        }
    }

    function loadXMLDoc(pageName)
    {
        var xmlhttp;
        if (window.XMLHttpRequest)
          {// code for IE7+, Firefox, Chrome, Opera, Safari
          xmlhttp=new XMLHttpRequest();
          }
        else
          {// code for IE6, IE5
          xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
        }
    xmlhttp.onreadystatechange=function()
          {
          if (xmlhttp.readyState==4 && xmlhttp.status==200)
            {
            document.getElementById("centreCont").innerHTML=xmlhttp.responseText;
            }
          }
        xmlhttp.open("GET","../profile/" + pageName + ".php",true);
        xmlhttp.send();
        }
}
</script>
4

1 回答 1

0

所以你说www.mysite.com/index.php?user=123当你点击你的按钮(或任何触发 AJAX 事件)时你正在打开,你将加载一个不同的 URL,它可能类似于www.mysite.com/myajaxpage.php.

在这种情况下,您可能忘记将用户参数传递给您的 AJAX 请求。所以你不能访问$_GET['user']inmyajaxpage.php因为它没有在你的 URL 中定义。

代码示例

如果你使用 jQuery,你可以这样做:

$.urlParam = function(name){
    var results = new RegExp('[\\?&amp;]' + name + '=([^&amp;#]*)').exec(window.location.href);
    return results[1] || 0;
}

// ....

$.post('myajaxpage.php', {'user': $.urlParam('user')}, function(data) {
   // your stuff
});

编辑:作者使用 Vanilla JS,所以这个例子毫无意义。

于 2013-08-23T20:31:16.257 回答