浅析PHP页⾯局部刷新功能的实现⼩结
⽅法其实挺多的。以前⽐较常⽤的是iframe这样来做。现在多了个ajax,所以⼀般情况下都是⽤的ajax。
当然,ajax使⽤起来确实很简单就可以实现,但是⾥⾯的很多知识还是⽐较有点深的。我之前做页⾯时间⾃动刷新的功能就是⽤的ajax。完整代码是:
复制代码代码如下:
<?php
header("cache-control:no-cache,must-revalidate");
header("Content-Type:text/html;charset=utf-8");
$time = "2012-1-20 18:00:00";
$dt_element=explode(" ",$time);
$date_element=explode("-",$dt_element[0]);
$time_element=explode(":",$dt_element[1]);
$date = mktime($time_element[0],$time_element[1],$time_element[2],$date_element[1],$date_element[2],$date_element[0]); $nowTime = time();
$showtime = date("北京时间Y年m⽉d⽇H:i:s",$date-$nowTime);
if($showtime<="北京时间1970年01⽉01⽇08:00:00"){
echo "happy new year";
}
echo $showtime;
复制代码代码如下:
</head>
<body>
<h1>Ajax动态显⽰时间</h1>
<input type="button" value="开始显⽰时间" id="go" onclick="start()" />
<p>当前时间:<font color="red"><span id="showtime"></span></font></p>
</body>
<script type="text/javascript">
var xmlHttp;
function createXMLHttpRequest(){
if(window.ActiveXObject){
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
else if(window.XMLHttpRequest){
xmlHttp = new XMLHttpRequest();
}
}
function start(){
createXMLHttpRequest();
var url="getTime.php";
xmlHttp.open("GET",url,true);
xmlHttp.send(null);
}
function callback(){
adyState == 4){
if(xmlHttp.status == 200){
setTimeout("start()",1000);
}
}
}
</script>
</html>
在浏览器⾥⾯直接访问zidong.php就可以了,点击⾥⾯的按钮就可以看到效果。
这个就是⽤ajax做的刷新页⾯局部内容的⼩例⼦。你可能会怀疑:这⾥⾯没有跟数据库交互啊?这还不简单,直接在
getTime.php页⾯⾥⾯操作就可以啦。
这种⽅法就不⽤多说了吧。⾄于ajax⾥⾯的代码是什么意思,不要问我啦,我之前就说过,这⾥⾯的ajax还是有点深的。
不要给我说⽤PHP 的include可以啊。你去试试吧。可以,可以就不会有那么多⼈在百度⾥⾯问了。
这种⽅法呢说起来复杂,其实还是挺简单的。说下原理吧:
要刷新的页⾯中把要⾃动刷新的局部的代码单独拿出来,做成⼀个独⽴的页⾯,⾃动刷新有很多种⽅法:可以在这个独⽴页⾯中⽤javascript来控制,什么setTimeout("start()",1000);啊或者setInterval("start()",1000);(每隔1秒刷新页⾯)这样,还可以⽤meta标签实现:<meta http-equiv="Refresh" content="10">(每隔10秒刷新页⾯)。这样在原来的页⾯中⽤iframe来将它调⽤过来。这样就可以了。
还是上⽰例代码吧:
复制代码代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<!--<meta http-equiv="refresh" content="5">-->
<title>Admin</title>
<script language="javascript" type="text/javascript" src="/extend/js/json.js" ></script>
<script language="javascript" type="text/javascript" src="/extend/menus.js"></script>
<script language="javascript" type="text/javascript" src="/extend/js/jquery-1.4.2.js"></script>
<link href="/css/main.css" rel="stylesheet" type="text/css" />
<link href="/css/question.css" rel="stylesheet" type="text/css" />
<script type="text/javascript">
//下⾯的isKeyTrigger()、ctrlEnter()、submitContent()⽅法是响应键盘事件提交内容的。兼容性不错。
function isKeyTrigger(e,keyCode){
var argv = isKeyTrigger.arguments;
var argc = isKeyTrigger.arguments.length;
var bCtrl = false;
if(argc > 2){
bCtrl = argv[2];
}
var bAlt = false;
if(argc > 3){
bAlt = argv[3];
}
var nav4 = window.Event ? true : false;
if(typeof e == 'undefined') {
e = event;
}
if( bCtrl &&
!((lKey != 'undefined') ?
return false;
}
if( bAlt &&
!((typeof e.altKey != 'undefined') ?
e.altKey : e.modifiers & Event.ALT_MASK > 0)){
return false;
}
var whichCode = 0;
if (nav4) whichCode = e.which;
else if (e.type == "keypress" || e.type == "keydown")
whichCode = e.keyCode;
else whichCode = e.button;
return (whichCode == keyCode);
}
function ctrlEnter(e){
var ie =navigator.appName=="Microsoft Internet Explorer"?true:false;  if(ie){
lKey && window.event.keyCode==13){  submitContent();
}
}else{
if(isKeyTrigger(e,13,true)){
submitContent();
}
}
}
function submitContent(){
save_answer();
}
function save_answer(){
var $content = $('#answer').val();
var $save_answer_url = '<?php echo $save_answer_url;?>';
if ( $content == '' ){
alert("no data!");
return;
}
var $post_data = {
content : $content ,
qid:'<?php echo $question['ID'];?>',
uid:'<?php echo $questionUser['ID'];?>'
};
//alert($save_answer_url);
$.ajax({
type : 'post' ,
url : $save_answer_url ,
data : $post_data ,
success : function( e ){
var $rs = JSON.decode( e );
if ( $rs.succ == 1 ){
alert("answer success!");
$('#answer').val("");
} else {
alert( $rs.msg );
}
}
});
}
//删除答案
function deleteanswer($id){
var $delete_answer_url = '<?php echo $delete_answer_url;?>';
var $post_data = {
id : $id
};
if(confirm("are you sure delete?")){
$.ajax({
type : 'post' ,
url : $delete_answer_url,
data : $post_data ,
success : function( e ){
var $rs = JSON.decode( e );
if ( $rs.succ == 1 ){
alert("delete success!");
} else {
alert( $rs.msg );
}
}
});
}
else{
return;
}
}
////设置为最佳答案
//function setbestanswer($id,$aid){
//  var $set_bestanswer_url = '<?php echo $set_bestanswer_url;?>';
//  var $post_data = {jquery实现ajax
//  id : $id ,
//  aid : $aid
//  };
//  if(confirm("are you sure set this answer is best?")){
//  $.ajax({
//  type : 'post' ,
/
/  url : $set_bestanswer_url,
//  data : $post_data ,
//  success : function( e ){
//  var $rs = JSON.decode( e );
//  if ( $rs.succ == 1 ){
//  alert("set success!");
//  load(); //刷新页⾯
//  } else {
//  alert( $rs.msg );
//  }
//  }
/
/  });
//  }
//  else{
//  return;
//  }
//
//}
</script>
<!--<script language="javascript">-->
<!--setInterval("myajax();",1000);-->
<!--function myajax()-->
<!--{-->
<!--  //获取信息json数组 -->
<!--  var html2 = "";-->
<!--  html2 = "<table id=\"answerTable\"><tr><td class=\"answerHead\" colspan=\"2\"> 回答:"+-->  <!--  "</td></tr><tr><td><iframe width=0 height=0 src=\"check_new.php\"></iframe></td></tr>"+-->  <!--  "<?php if (isset($answers) && !empty($answers)) {foreach ($answers as $key=>$value){?>"+-->  <!--  "<tr><td class=\"boss\">"+-->
<!--  "<?php echo $value['Answer'];?>"+-->
<!--  "</td><td style=\"text-align:right;\">"+-->
<!--  "<?php if($_SESSION['ADMINISTRATOR']){?>"+-->
<!--  "<a href=\"javascript:deleteanswer(<?php echo $value['ID'];?>);\">"+-->
<!--  "<img src=\"/images/questiondelete.jpg\"  style=\"border:0;\"/></a>"+-->
<!--  "<?php  }?>"+-->
<!--  "</td></tr><tr><td class=\"answerAuthor\" colspan=\"2\">回答者:"+-->
<!--  "<?php echo $value['Email'];?>"+-->
<!--  "  回答时间:"+-->
<!--  "<?php echo $value['Date'];?>"+-->
<!--  "</td></tr><tr><td colspan=\"2\"><hr style=\"border: 1px dashed #ccc; width: 100%; height: 1px;\" /></td></tr>"+-->
<!--  "<?php }}else{?>"+-->
<!--  "<tr><td style=\"text-align:center;height:80px;\" colspan=\"2\">该问题⽬前还没有⽤户回答,你可以在下⾯填写内容来回答</td></tr>"+-->
<!--  "<?php }?>  </table>";-->
<!--  $("#answerDiv").html(html2);-->
<!--}-->
<!--</script>-->
<!--<script type="text/javascript">-->
<!--var xmlHttp;-->
<!--function createXMLHttpRequest(){-->
<!-- if(window.ActiveXObject){-->
<!--  xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");-->
<!-- }-->
<!-- else if(window.XMLHttpRequest){-->
<!--  xmlHttp = new XMLHttpRequest();-->
<!-- }-->
<!--}-->
<!--function start(){-->
<!-- //alert("laslfda;f");-->
<!-- createXMLHttpRequest();-->
<!-- var url="/extend/check_new.php?sid="+Math.random()";-->
<!-- //var url = "../../view/product/check_new.php";-->
<!-- //alert(url);-->
<!-- xmlHttp.open("GET",url,true);-->
<!-- //alert(url);-->
<!-- adystatechange = callback;-->
<!-- xmlHttp.send(null);-->
<!--}-->
<!--function callback(){-->
<!-- adyState == 4){-->
<!--  //alert("asdflasdf");-->
<!--  //if(xmlHttp.status == 200){-->
<!--  ElementById("answerDiv").innerHTML = sponseText;-->
<!--  //ElementById("answerDiv").innerHTML);-->
<!--  setTimeout("start()",1000);-->
<!--  //}-->
<!--  //alert(xmlHttp.status);-->
<!-- }-->
<!--}-->
<!--setInterval("start()",1000);-->
<!--</script>-->
</head>
<body onkeydown="javascript:ctrlEnter(event);">
<center>
<div class="Container">
<table>
<tr>
<th class="zongHead" colspan="2">  产品问题及回答详细列表</th>
</tr>
<tr>
<td colspan="2"><hr/></td>
</tr>
<tr>
<td class="questionHead" colspan="2"> 该问题详细内容:</td>
</tr>
<?php
if (isset($question) && !empty($question)) {
>
<tr>
<td class="questionContent" colspan="2"><?php echo $question['Question'];?></td>