DDR爱好者之家 Design By 杰米
JavaScript Ajax实现异步通信
一、浏览器与服务器的同步和异步通信
1.同步:是阻塞的,浏览器在向服务器发送请求之后一直等待服务器的响应,而没有做其他事情。
2.异步:非阻塞的,浏览器向服务器发送请求之后,继续执行其他代码,知道服务器响应,浏览器中断当前的任务,处理服务器响应。
二、没有Ajax之前浏览器是通过iframe来实现异步刷新
1.iframe标签:iframe标签通过src连接到一个页面,其实就是将需要实现异步刷新的内容使用
iframe标签包裹,
A.对iframe实现整个页面刷新,其实是通过刷新一个页面的子页面来实现异步刷新;
a.主页面代码:
<div>通过实现子页面刷新来实现异步刷新</div> <iframe src="/UploadFiles/2021-04-02/data.php">b.php页面代码:
<"htmlcode"><div id="refreshTarget"></div> <form action="../php/data.php" method="post" target="targetIframe"> <input type="submit" value="提交"> </form> <iframe name="targetIframe" frameborder="0">iframe</iframe>b.php页面代码:
<"text/javascript"> parent.document.querySelector('#refreshTarget').innerHTML = '刷新成功'; </script>三、Ajax实现异步刷新
1.使用get方法来发送请求:
/** * 使用ajax get方式来验证用户名密码是否正确 * 1.区别于表单,我们需要自己拼接查询字符串,不是表单提交,可 * 以不为表单添加name属性 * 2.将数据放在查询字符串中传到请求的页面,然后页面获得数据进 * 行操作,然后对前端返回响应数据,解析数据,刷新 */ var submit = document.querySelector('#submit'); submit.onclick = function(){ var nameValue = document.querySelector('#username').value; var passValue = document.querySelector('#password').value; var target = document.querySelector('#refreshTarget'); /* 实例化XMLHttpResquest*/ var xhr = new XMLHttpRequest(); /* 监控xhr对象的状态,只要xhr.readyState值改变就会触发事件由alert弹出框的值可以知道 a.以下xhr.readyState值为4的时候表示请求响应结束,数据接收完毕并且可以使用 b.xhr.status值为200表示请求成功 */ xhr.onreadystatechange = function() { alert(1); if(xhr.readyState == 4) { if(xhr.status == 200){ var data = xhr.responseText; if(data == 1) { target.innerHTML = '验证成功'; }else if(data == 2) { target.innerHTML = '验证失败'; } } } } /* 打开请求*/ var url = '../testphp/inspector.php"htmlcode">/** * 使用ajax post方式来验证用户名密码是否正确 * 1.区别于表单,我们需要自己拼接查询字符串,不是表单提交,可 * 以不为表单添加name属性 * 2.将数据放在查询字符串中传到请求的页面,然后页面获得数据进 * 行操作,然后对前端返回响应数据,解析数据,刷新 * 3.区别于ajax,get方法就是数据是放在send发送不是添加到查询字符串 */ var submit = document.querySelector('#submit'); submit.onclick = function(){ var nameValue = document.querySelector('#username').value; var passValue = document.querySelector('#password').value; var target = document.querySelector('#refreshTarget'); /* 实例化XMLHttpResquest*/ var xhr = new XMLHttpRequest(); /* 监控xhr对象的状态,只要xhr.readyState值改变就会触发事件由alert弹出框的值可以知道 a.以下xhr.readyState值为4的时候表示请求响应结束,数据接收完毕并且可以使用 b.xhr.status值为200表示请求成功 */ xhr.onreadystatechange = function() { alert(1); if(xhr.readyState == 4) { if(xhr.status == 200){ var data = xhr.responseText; if(data == 1) { target.innerHTML = '验证成功'; }else if(data == 2) { target.innerHTML = '验证失败'; } } } } /* 打开请求*/ var url = '../testphp/inspector.php"htmlcode"><?php /* 设置响应数据的内容格式,和字符集*/ header('Content-type:text/html;charset=utf-8'); /*使用表单的post请求php页面中可以通过$_POST来获取*/ $username = $_POST['username']; $password = $_POST['password']; if($username == 'admin' && $password == '123'){ echo 1; }else{ echo 2; } ?>以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年11月28日
2024年11月28日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓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]