为什么ajax代码在IE,Chrome,FireFox 5.0中有效但在FireFox 3中不起作用?

时间:2011-07-27 08:29:28

标签: php ajax firefox-3

我从互联网上获得了一个简单的AJAX演示代码,它使用数据库中的值动态填充一个选择列表框。它包含一个嵌入了AJAX代码的html文件和一个PHP文件。

问题是此代码在IE,Chrome,FireFox4中运行良好,但它在FireFox3中不起作用。请任何人解释一下并告诉我解决方案。代码如下以供参考

city表的数据库架构如下

id tinyint(4) primary key not null
city varchar(50)
countryid tinyint(4)

HTML文件

<html>
<head>
<script type="text/javascript">
function getCity(strURL)
{         
alert("inside getCity function");
//var req = getXMLHTTP(); // function to get xmlhttp object

if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
    //xmlhttp=new XMLHttpRequest();
    req=new XMLHttpRequest();
}
else
{// code for IE6, IE5
    //xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
    req=new ActiveXObject("Microsoft.XMLHTTP");
}

if (req)
{
    req.onreadystatechange = function()
    {
        if (req.readyState == 4) { //data is retrieved from server
            if (req.status == 200) { // which reprents ok status                    
                document.getElementById('citydiv').innerHTML=req.responseText;
            }
            else
            { 
                alert("There was a problem while using XMLHTTP:\n");
            }
        }            
    }        
    //alert(srtURL);
    var sURL="findcity.php?country="+strURL;
    req.open("GET", sURL, true); //open url using get method
    req.send();
}
}
</script>
</head>
<body>
<form method="post" action="" name="form1">
Country : <select name="country" onChange="getCity(this.value)">
<option value="">Select Country</option>
<option value="1">india</option>
<option value="2">usa</option>
</select>
<br />City : <div id="citydiv">
<select name="select">
<option>Select City</option>
 </select>
</div>
</form>
</body>
</html>

PHP文件

<? 
echo $_GET['country'];
echo "<br>";
$country=intval($_GET['country']);
echo $country;
echo "<br>";
$link = mysql_connect('localhost', 'root', 'mark'); //change the configuration if required
if (!$link) {
  die('Could not connect: ' . mysql_error());
}
mysql_select_db('querytest'); //change this if required
$query="select city from city where countryid=$country";
echo "<br>";
echo $query;
echo "<br>";
$result=mysql_query($query);?>
<select name="city">
<option>Select City</option>
<? while($row=mysql_fetch_array($result)) { ?>
   <option value><?=$row['city']?></option>
<? } ?>
</select>

请引导我的朋友将此代码用于FireFox 3

1 个答案:

答案 0 :(得分:0)

更改

req.send();

req.send(null);