在 index.php 中的 $(document).ready(function() 上,执行以下 AJAX,运行文件 getData.php:
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("dataSuccess").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","getData.php",true);
xmlhttp.send();
在 getData.php 文件中,从 MySQL 收集数据并放入 JS 数组中:
var guestData = new Array("<? for ($j=0;$j< sizeof($guestData);$j++) { print ($guestData[$j]); ?>","<?php } $j = $j+1; ?>");
最后,将我的 js 数组中的数据存储到 LocalStorage 中:
var guestDataCols = new Array();
guestDataCols = guestData[0].split(",")
var arrayIndex=0;
for(arrayIndex=0;arrayIndex<guestData.length-1;arrayIndex++)
{
localStorage.setItem(arrayIndex, guestData[arrayIndex]); // storing
}
一切正常!但问题是我的 AJAX 代码似乎没有运行整个 getData.php 文件,因为在通过 AJAX 执行 php 文件后 LocalStorage 仍然为空。但是(这是一个很大的问题),如果我只是在另一个窗口中刷新 getData.php,数据将被完美存储并且一切正常。正如另一个 Stack Overflow 问题中所建议的那样,我也尝试过使用jQuery
$('#dataSuccess').load('getData.php'); //instead for the AJAX code
但结果完全相同且有些平庸。所以我的问题是,为什么 AJAX 脚本不运行整个 php 文件和HENCE,为什么没有数据存储在 LocalStorage 中?