电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

php下的原生ajax請求用法實例分析

瀏覽:147日期:2022-09-11 13:18:54

本文實例講述了php下的原生ajax請求用法。分享給大家供大家參考,具體如下:

瀏覽器中為我們提供了一個JS對象XMLHttpRequet,它可以幫助我們發送HTTP請求,并接受服務端的響應。

意味著我們的瀏覽器不提交,通過JS就可以請求服務器。

ajax(Asynchronous Javascript And XML)其實就是通過XHR對象,執行HTTP請求。

1、創建XHR對象

var xhr = new XMLHttpRequest(); //暫不考慮兼容

2、XHR的對象屬性和方法

方法:open('get/post', url, true/false);//有參數則k=v&k1=v1這種形式send(null);屬性://代表請求狀態,不斷變化,為4時,請求結束readyState//響應的內容responseText//響應的狀態碼200,403,404status//狀態文字statusText事件://當readyState變化時會觸發此事件onreadystatechange = function() {};

3、通過XHR對象發送get請求

<!DOCTYPE html><html> <head> <title>ajax</title> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1.0'> </head> <body> <div id='box'> <input type='text' name='con' value='' /> </div> </body> <script type='text/javascript'> var ipt = document.getElementById('con'); ipt.onblur = function () { var con = this.value; //創建XHR對象 var xhr = new XMLHttpRequest(); //設置請求URL var url = './ajax.php?con=' + con; //設置XHR對象readyState變化時響應函數 xhr.onreadystatechange = function () {//readyState是請求的狀態,為4表示請求結束if (xhr.readyState == 4) { //responseText服務器響應的內容 alert('服務器響應數據:' + this.responseText);} }; //打開鏈接 xhr.open('get', url, true); //發送請求 xhr.send(null); } </script></html>

ajax.php如下:

<?php$con = !empty($_GET[’con’]) ? trim($_GET[’con’]) : ’沒有數據’;echo $con;

填入數據,當鼠標焦點離開input時,觸發請求,彈出響應內容。

4、通過XHR對象發送post請求

(1)、open()第1參數為post

(2)、POST的參數以k=v&k1=v1&k2=v2的形式拼接,并用send()發送

(3)、必須要設置Content-Type為application/x-www-form-urlencoded

<!DOCTYPE html><html> <head> <title>ajax</title> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1.0'> </head> <body> <div id='box'> <input type='text' name='name' value='' /> <input type='password' name='pwd' value='' /> <input type='submit' name='sub' value='提交' /> </div> </body> <script type='text/javascript'> var sub = document.getElementById('sub'); sub.onclick = function () { var name = document.getElementById('name').value; var pwd = document.getElementById('pwd').value; //創建XHR對象 var xhr = new XMLHttpRequest(); //設置請求URL var url = './ajax.php'; //設置XHR對象readyState變化時響應函數 xhr.onreadystatechange = function () {//readyState是請求的狀態,為4表示請求結束if (xhr.readyState == 4) { //responseText服務器響應的內容 alert('服務器響應數據:' + this.responseText);} }; //打開鏈接 xhr.open('post', url, true); //設置請求頭部 xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); //發送請求 xhr.send('name=' + name + '&pwd=' + pwd); } </script></html>

ajax.php如下:

<?php$name = !empty($_POST[’name’]) ? trim($_POST[’name’]) : ’沒有數據’;$pwd = !empty($_POST[’pwd’]) ? trim($_POST[’pwd’]) : ’沒有數據’;echo ’用戶名:’, $name, ’密碼:’, $pwd;

單擊submit后發送post請求,彈出響應信息。

5、返回值json,html,text,xml

返回值只有兩種text,和xml。不過text內容中可以是一段html或json結構的字符串。

(1)、返回json格式

<!DOCTYPE html><html> <head> <title>ajax</title> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1.0'> </head> <body> <div id='box'> <select id='city'></select> <input type='button' value='獲取' /> </div> </body> <script type='text/javascript'> var get = document.getElementById('get'); var city = document.getElementById('city'); get.onclick = function () { //創建XHR對象 var xhr = new XMLHttpRequest(); //設置請求URL var url = './ajax.php'; //設置XHR對象readyState變化時響應函數 xhr.onreadystatechange = function () {//readyState是請求的狀態,為4表示請求結束if (xhr.readyState == 4) { //responseText服務器響應的內容 //通過eval把傳來的json字符串轉成對象 var data = eval(this.responseText); var str = ''; for(var ix in data) { str += '<option value=’' + data[ix].id + '’>' + data[ix].name + '</option>'; } city.innerHTML = str;} }; //打開鏈接 xhr.open('get', url, true); //發送請求 xhr.send(null); } </script></html>

ajax.php如下:

<?php$data = array( array(’id’ => 1, ’name’ => ’上海’), array(’id’ => 2, ’name’ => ’北京’), array(’id’ => 3, ’name’ => ’深圳’),);echo json_encode($data);

(2)、返回xml格式

xml通過responseXML來讀取,responseXML不是字符串,是DOM對象。

<!DOCTYPE html><html> <head> <title>ajax</title> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1.0'> </head> <body> <div id='box'> <div id='news'></div> <input type='button' value='獲取' /> </div> </body> <script type='text/javascript'> var get = document.getElementById('get'); var news = document.getElementById('news'); get.onclick = function () { //創建XHR對象 var xhr = new XMLHttpRequest(); //設置請求URL var url = './ajax.php'; //設置XHR對象readyState變化時響應函數 xhr.onreadystatechange = function () {//readyState是請求的狀態,為4表示請求結束if (xhr.readyState == 4) { //responseXML服務器響應的內容 var data = this.responseXML; var str = ''; var title = data.getElementsByTagName('title'); str += '<p>' + title[0].childNodes[0].nodeValue + '</p>'; str += '<p>' + title[1].childNodes[0].nodeValue + '</p>'; str += '<p>' + title[2].childNodes[0].nodeValue + '</p>'; news.innerHTML = str;} }; //打開鏈接 xhr.open('get', url, true); //發送請求 xhr.send(null); } </script></html>

ajax.php如下:

<?phpheader(’Content-Type: text/xml;charset=utf-8’);$xml = <<<EOD<?xml version='1.0' encoding='utf-8'?><news> <title>111</title> <title>222</title> <title>333</title></news>EOD;echo $xml;

6、ajax的同步與異步

通過設置open()的第三個參數true/false,來查看請求的效果。

同步請求:

發送請求->等待結果->操作完成->繼續后面代碼。我們必須等待結果處理完畢后才能繼續后面的代碼,嚴格按照步驟一步一步執行。

異步請求:

發送請求->繼續后面代碼->響應結果接收完畢->操作結果。異步請求在發送請求之后沒有等待結果的返回而是繼續執行后面的代碼,也就是說在結果返回之前用戶可以操作其他東西。

更多關于PHP相關內容可查看本站專題:《PHP+ajax技巧與應用小結》、《PHP網絡編程技巧總結》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家PHP程序設計有所幫助。

標簽: PHP
相關文章:
主站蜘蛛池模板: 今日娱乐圈——影视剧集_八卦娱乐_明星八卦_最新娱乐八卦新闻 | 皮带输送机-大倾角皮带输送机-皮带输送机厂家-河南坤威机械 | 焊锡丝|焊锡条|无铅锡条|无铅锡丝|无铅焊锡线|低温锡膏-深圳市川崎锡业科技有限公司 | 康明斯发电机,上柴柴油发电机,玉柴柴油发电机组_海南重康电力官网 | ptc_浴霸_大巴_干衣机_呼吸机_毛巾架_电动车加热器-上海帕克 | 洗砂机械-球磨制砂机-洗沙制砂机械设备_青州冠诚重工机械有限公司 | 济南轻型钢结构/济南铁艺护栏/济南铁艺大门-济南燕翔铁艺制品有限公司 | 培训中心-翰香原香酥板栗饼加盟店总部-正宗板栗酥饼技术 | 生物风-销售载体,基因,质粒,ATCC细胞,ATCC菌株等,欢迎购买-百风生物 | 冷却塔改造厂家_不锈钢冷却塔_玻璃钢冷却塔改造维修-广东特菱节能空调设备有限公司 | 国际线缆连接网 - 连接器_线缆线束加工行业门户网站 | 课件导航网_ppt课件_课件模板_课件下载_最新课件资源分享发布平台 | 骨灰存放架|骨灰盒寄存架|骨灰架厂家|智慧殡葬|公墓陵园管理系统|网上祭奠|告别厅智能化-厦门慈愿科技 | 成都办公室装修-办公室设计-写字楼装修设计-厂房装修-四川和信建筑装饰工程有限公司 | 蒸汽热收缩机_蒸汽发生器_塑封机_包膜机_封切收缩机_热收缩包装机_真空机_全自动打包机_捆扎机_封箱机-东莞市中堡智能科技有限公司 | 污水/卧式/潜水/钻井/矿用/大型/小型/泥浆泵,价格,参数,型号,厂家 - 安平县鼎千泵业制造厂 | 压力变送器-上海武锐自动化设备有限公司 | 生物风-销售载体,基因,质粒,ATCC细胞,ATCC菌株等,欢迎购买-百风生物 | 大型工业风扇_工业大风扇_大吊扇_厂房车间降温-合昌大风扇 | 江西自考网-江西自学考试网| 3D全息投影_地面互动投影_360度立体投影_水幕灯光秀 | 广东银虎 蜂窝块状沸石分子筛-吸附脱硫分子筛-萍乡市捷龙环保科技有限公司 | 北京租车牌|京牌指标租赁|小客车指标出租 | RV减速机-蜗轮蜗杆减速机-洗车机减速机-减速机厂家-艾思捷 | 石家庄救护车出租_重症转院_跨省跨境医疗转送_活动赛事医疗保障_康复出院_放弃治疗_腾康26年医疗护送转诊团队 | 不锈钢监控杆_监控立杆厂家-廊坊耀星光电科技有限公司 | 北京三友信电子科技有限公司-ETC高速自动栏杆机|ETC机柜|激光车辆轮廓测量仪|嵌入式车道控制器 | 厚壁钢管-厚壁无缝钢管-小口径厚壁钢管-大口径厚壁钢管 - 聊城宽达钢管有限公司 | 冲击式破碎机-冲击式制砂机-移动碎石机厂家_青州市富康机械有限公司 | 蓝米云-专注于高性价比香港/美国VPS云服务器及海外公益型免费虚拟主机 | 依维柯自动挡房车,自行式国产改装房车,小型房车价格,中国十大房车品牌_南京拓锐斯特房车 - 南京拓锐斯特房车 | J.S.Bach 圣巴赫_高端背景音乐系统_官网| Q361F全焊接球阀,200X减压稳压阀,ZJHP气动单座调节阀-上海戎钛 | PSI渗透压仪,TPS酸度计,美国CHAI PCR仪,渗透压仪厂家_价格,微生物快速检测仪-华泰和合(北京)商贸有限公司 | 搬运设备、起重设备、吊装设备—『龙海起重成套设备』 | 「银杏树」银杏树行情价格_银杏树种植_山东程锦园林 | 出国劳务公司_正规派遣公司[严海] | 浙江红酒库-冰雕库-气调库-茶叶库安装-医药疫苗冷库-食品物流恒温恒湿车间-杭州领顺实业有限公司 | 焊锡丝|焊锡条|无铅锡条|无铅锡丝|无铅焊锡线|低温锡膏-深圳市川崎锡业科技有限公司 | 汽液过滤网厂家_安平县银锐丝网有限公司| 包装设计公司,产品包装设计|包装制作,包装盒定制厂家-汇包装【官方网站】 | 桁架机器人_桁架机械手_上下料机械手_数控车床机械手-苏州清智科技装备制造有限公司 |