本文实例讲述了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,404 status //状态文字 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="" id="con" /> </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; //设置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如下:
<"htmlcode"><!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="" id="name" /> <input type="password" name="pwd" value="" id="pwd" /> <input type="submit" name="sub" value="提交" id="sub" /> </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如下:
<"htmlcode"><!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="获取" id="get" /> </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如下:
<"htmlcode"><!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="获取" id="get" /> </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如下:
<"1.0" encoding="utf-8""_blank" href="//www.jb51.net/Special/328.htm">PHP+ajax技巧与应用小结》、《PHP网络编程技巧总结》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》希望本文所述对大家PHP程序设计有所帮助。
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
更新日志
2024年11月29日
2024年11月29日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]