经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » AJAX » 查看文章
Ajax引擎:ajax请求步骤详细代码
来源:cnblogs  作者:山风和薰  时间:2018/10/15 9:07:28  对本文有异议

说起AJAX,可能是很多同学在很多地方都看到过,各大招聘网站上对于WEB前端和PHP程序员的技能要求清单中也是必不可少的一项。但是,ajax请求步骤详细代码以及说明却比较少见到

什么是AJAX引擎?

AJAX引擎其实是一个JavaScript对象,全写是 window.XMLHttpRequest对象,由于浏览器的版本不同,特别是老版本的IE浏览器,虽然也支持AJAX引擎,但是写法上有区别,在IE低版本中通常用 ActiveXObject对象来创建AJAX引擎。 AJAX 来自英文“Asynchronous Javascript And XML” 的缩写,也称为异步JavaScript和XML。 简言之,就是一个JS对象,可以实现在网页加载完成以后,不用刷新的情况下与服务器交互。产生极好的用户体验效果。

AJAX用来做什么?

AJAX技术广泛应用于实现用户体验良好的一个个交互功能,比如:
image

搜索产品时的关键词推荐

image

注册新用户的重名提示

现在网站几乎全部都使用Ajax技术,最具有代表使用Ajax技术的网站有:新浪微博、Google地图、百度搜索、淘宝网等等。

AJAX的实现原理

Ajax的原理简单来说通过浏览器的javascript对象XMLHttpRequest(Ajax引擎)对象向服务器发送异步请求并接收服务器的响应数据,然后用javascript来操作DOM而更新页面。这其中最关键的一步就是从服务器获得请求数据。即用户的请求间接通过Ajax引擎发出而不是通过浏览器直接发出,同时Ajax引擎也接收服务器返回响应的数据,所以不会导致浏览器上的页面全部刷新。

image

AJAX请求步骤详细代码

由于AJAX是一项从客户端发起,和服务器进行交互的技术,所以必须涉及两个方面:客户端和服务器端,下面咱们以会员注册的用户名为例给大家写一个AJAX的详细请求步骤和代码:

客户端代码 reg.html

  1. <!DOCTYPE html>
  2.  
  3. <html>
  4. <head>
  5.  
  6. <meta charset="utf-8"/>
  7.  
  8. <title>AJAX引擎实现用户名重名检测</title>
  9.  
  10. </head>
  11.  
  12. <body>
  13.  
  14. <form>
  15.  
  16. <p>用户名:<input type="text" name="username" id="username"/> <span id="result"></span></p>
  17.  
  18. <p>密码:<input type="password" name="pwd1"/></p>
  19.  
  20. <p>确认密码:<input type="password" name="pwd2"/></p>
  21.  
  22. <p><input type="button" value="立即注册"/></p>
  23.  
  24. </form>
  25.  
  26. <script type="text/javascript">
  27.  
  28. var username=document.getElementById('username');
  29.  
  30. //用户名输入框失去焦点时触发
  31.  
  32. username.onblur=function(){
  33.  
  34. //主角登场——AJAX引擎的创建及使用详细代码来了
  35.  
  36. var ajax=new XMLHttpRequest(); //创建AJAX引擎实例
  37.  
  38. //创建GET请求,发送请求时传username值
  39.  
  40. ajax.open('GET','check.php?username='+this.value); 
  41.  
  42. //当AJAX引擎的状态产生改变时触发onreadystatechange属性指向的函数(多次执行)
  43.  
  44. //状态值有5个:0 1 2 3 4 ,其中4表示服务器端响应就绪
  45.  
  46. ajax.onreadystatechange=function(){
  47.  
  48. //必须在服务器响应就绪,并且HTTP的状态码是200时才接收数据
  49.  
  50. //ajax.readyState 获取到服务器响应状态码,必须是4才表示就绪
  51.  
  52. //ajax.status 获取到HTTP的状态码,必须是200才表示成功
  53.  
  54. if(ajax.readyState==4 && ajax.status==200){
  55.  
  56. //ajax.responseText 接收服务器响应回来的内容
  57.  
  58. //console.log(ajax.responseText);
  59.  
  60. //接收到服务器响应数据后,AJAX工作已完成,可根据结果显示提示信息
  61.  
  62. If(ajax.responseText=='1'){
  63.  
  64. result.innerHTML='该用户名太受欢迎,请重新选择';
  65.  
  66. result.style.color='#f00'; //将字体设置为红色
  67.  
  68. }else{
  69.  
  70. result.innerHTML='恭喜你,可以注册';
  71.  
  72. result.style.color='#0a0'; //将字体设置为绿色
  73.  
  74. }
  75.  
  76. }
  77.  
  78. }
  79.  
  80. ajax.send(); //发送请求
  81.  
  82. }
  83.  
  84. </script>
  85.  
  86. </body>
  87.  
  88. </html>

服务器端代码 check.php

  1. //服务器端的代码可以使用PHP编写,根据逻辑反馈数据给客户端实现验证功能
  2.  
  3. $username=$_GET['username'];
  4.  
  5. //连接数据库的代码省略
  6.  
  7. $sql="select id from users where username='$username'";
  8.  
  9. $rs=mysqli_query($link,$sql); //将构造好的SQL语句发到服务器上执行
  10.  
  11. if( mysqli_num_rows($rs) ){
  12.  
  13. echo '1'; //如果用户名找到有结果,证明该用户名已存在,返回1
  14.  
  15. }else{
  16.  
  17. echo '0'; //如果用户名未找到结果,证明该用户名不存在,返回0
  18.  
  19. }
  20.  
  21. //关闭数据库连接,释放结果集

==附:AJAX的方法和属性表==

方法:
image
属性:
image
最后,注意一个重要的问题,XMLHttpRequest对象是没有跨域能力的,也就是说 ajax不能请求获得其它网站的数据,那有没有解决办法呢? 答案是肯定的,需要使用JSONP……

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号