/** * 初始化一個xmlhttp對象 */ function InitAjax() { var ajax=false; try { ajax = new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try { ajax = new ActiveXObject("Microsoft.XMLHTTP"); } catch (E) { ajax = false; } } if (!ajax && typeof XMLHttpRequest!=‘undefined‘) { ajax = new XMLHttpRequest(); } return ajax; } |
//將鏈接改為: <a href="#" onClick="getNews(1)">新聞1</a> //并且設(shè)置一個接收新聞的層,并且設(shè)置為不顯示: <div id="show_news"></div> 同時構(gòu)造相應(yīng)的JavaScript函數(shù): function getNews(newsID) { //如果沒有把參數(shù)newsID傳進來 if (typeof(newsID) == ‘undefined‘) { return false; } //需要進行Ajax的URL地址 var url = "/show.php?id="+ newsID; //獲取新聞顯示層的位置 var show = document.getElementById("show_news"); //實例化Ajax對象 var ajax = InitAjax(); //使用Get方式進行請求 ajax.open("GET", url, true); //獲取執(zhí)行狀態(tài) ajax.onreadystatechange = function() { //如果執(zhí)行是狀態(tài)正常,那么就把返回的內(nèi)容賦值給上面指定的層 if (ajax.readyState == 4 && ajax.status == 200) { show.innerHTML = ajax.responseText; } } //發(fā)送空 ajax.send(null); } |
//構(gòu)建一個表單,表單中不需要action、method之類的屬性,全部由ajax來搞定了。 <form name="user_info"> 姓名:<input type="text" name="user_name" /><br /> 年齡:<input type="text" name="user_age" /><br /> 性別:<input type="text" name="user_sex" /><br /> <input type="button" value="提交表單" onClick="saveUserInfo()"> </form> //構(gòu)建一個接受返回信息的層: <div id="msg"></div> |
function saveUserInfo() { //獲取接受返回信息層 var msg = document.getElementById("msg"); //獲取表單對象和用戶信息值 var f = document.user_info; var userName = f.user_name.value; var userAge = f.user_age.value; var userSex = f.user_sex.value; //接收表單的URL地址 var url = "/save_info.php"; //需要POST的值,把每個變量都通過&來聯(lián)接 var postStr = "user_name="+ userName +"&user_age="+ userAge +"&user_sex="+ userSex; //實例化Ajax var ajax = InitAjax(); //通過Post方式打開連接 ajax.open("POST", url, true); //定義傳輸?shù)奈募﨟TTP頭信息 ajax.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); //發(fā)送POST數(shù)據(jù) ajax.send(postStr); //獲取執(zhí)行狀態(tài) ajax.onreadystatechange = function() { //如果執(zhí)行狀態(tài)成功,那么就把返回信息寫到指定的層里 if (ajax.readyState == 4 && ajax.status == 200) { msg.innerHTML = ajax.responseText; } } } |
//上傳表單,指定target屬性為浮動框架iframe1 <form action="/upload.php" method="post" enctype="multipart/form-data" name="upload_img" target="iframe1"> 選擇要上傳的圖片:<input type="file" name="image"><br /> <input type="submit" value="上傳圖片"> </form> //顯示提示信息的層 <div id="message" style="display:none"></div> //用來做目標窗口的浮動框架 <iframe name="iframe1" width="0" height="0" scrolling="no"></iframe> |
<?php /* 定義常量 */ //定義允許上傳的MIME格式 define("UPLOAD_IMAGE_MIME", "image/pjpeg,image/jpg,image/jpeg,image/gif,image/x-png,image/png"); //圖片允許大小,字節(jié) define("UPLOAD_IMAGE_SIZE", 102400); //圖片大小用KB為單位來表示 define("UPLOAD_IMAGE_SIZE_KB", 100); //圖片上傳的路徑 define("UPLOAD_IMAGE_PATH", "./upload/"); //獲取允許的圖像格式 $mime = explode(",", USER_FACE_MIME); $is_vaild = 0; //遍歷所有允許格式 foreach ($mime as $type) { if ($_FILES[‘image‘][‘type‘] == $type) { $is_vaild = 1; } } //如果格式正確,并且沒有超過大小就上傳上去 if ($is_vaild && $_FILES[‘image‘][‘size‘]<=USER_FACE_SIZE && $_FILES[‘image‘][‘size‘]>0) { if (move_uploaded_file($_FILES[‘image‘][‘tmp_name‘], USER_IMAGE_PATH . $_FILES[‘image‘][‘name‘])) { $upload_msg ="上傳圖片成功!"; } else { $upload_msg = "上傳圖片文件失敗"; } } else { $upload_msg = "上傳圖片失敗,可能是文件超過". USER_FACE_SIZE_KB ."KB、或者圖片文件為空、或文件格式不正確"; } //解析模板文件 $smarty->assign("upload_msg", $upload_msg); $smarty->display("upload.tpl"); > 模板文件:upload.tpl {if $upload_msg != ""} callbackMessage("{$upload_msg}"); {/if} //回調(diào)的JavaScript函數(shù),用來在父窗口顯示信息 function callbackMessage(msg) { //把父窗口顯示消息的層打開 parent.document.getElementById("message").style.display = "block"; //把本窗口獲取的消息寫上去 parent.document.getElementById("message").innerHTML = msg; //并且設(shè)置為3秒后自動關(guān)閉父窗口的消息顯示 setTimeout("parent.document.getElementById(‘message‘).style.display = ‘none‘", 3000); } |