在所有主流的网站,基本上都用到了ajax技术,通过异步请求数据已经是一个很普及的实现方式。市面上主流的web前端框架也都有自己封装的ajax,而且都是大同小异的。也就是说,Ajax这个轮子已经是多的不能再多了,那为什么我们还要自己封装一个Ajax呢?
想要了解一个技术或者某个功能的实现原理,只有动手实践才能真正的了解。就如我在csdn上第一篇博客的博文描述。探索技术的路上本应该自己造轮子,即使市面上有再多的选择,自己动手尝试也是必要的,第一次尝试必然会问题众多,但你不觉得解决他是一件很有成就感的事情吗,这样才能带给你更大的进步和更深刻的领悟。
废话不说,先来写一个最基础的ajax:
[javascript] view plain copy
一个ajax出炉了,通过调用、填写参数即可请求到服务器。先来分析一下这个ajax的结构,可以看得出来,其实很简单,只是new了一个XMLHttpRequest对象,然后通过onreadystatechange方法来处理返回值,现在我们只是做了一个判断,当请求成功时就调用success方法,如果请求失败,我们还没有写上去,后面我们慢慢完善这个ajax的逻辑。
然后调用ajax的open方法,open方法里有三个参数,第一个是请求方式(如:get或post),第二个是请求的url地址,第三个是一个bool值,是否要异步请求。
最后使用send方法带上参数发送请求即可。
这是,我的服务器已经收到一个请求,但他报了404错误,也就是找不到对应的页面或路由,这时success方法也不会被调用执行。
那我们再来完善一下这个新生的ajax。我们只需要在onreadystatechange方法里增加一个条件,当请求不成功时调用自身的error方法:
[javascript] view plain copy
这样我们就可以在ajax请求的时候加上error方法,当ajax请求失败的时候执行我们想要执行的操作。现在我们抛除跨域请求的问题,当你发送post请求时,你会发现后台接收不到传过来的参数,调用如下:
[javascript] view plain copy
后端打印一下传过来的参数,为空。
出现这个问题的原因主要是请求头没有声明,这时候我们需要初始化声明一下请求头,那我们加入一行代码:
[javascript] view plain copy
设置Conten-type为application/x-www-form-urlencoded,现在后端应该是已经可以收到参数了。那我们现在的ajax调用时实在太繁琐,有些东西我们不想填的我们应该给他设置一个默认值,不然就会报错。
比如error方法、method、还有是否异步的bool值等等。那我们再加入一些默认值,现在的ajax是这样的:
[javascript] view plain copy
现在的ajax还存在一个问题,在post请求的时候,如果我们要传参,是需要通过字符串传参的。那这种的书写规则并不是很友好的:
[javascript] view plain copy
而一般框架的传参都是通过json的格式来输入的,我们也不能偏离大众习惯搞独立,当然我们也要保留字符串的传参方式,只是要扩展功能。
那我们需要加一个控制格式的参数,我们这里用dataType这个参数来控制传参格式,默认是字符串格式传参好了,可以选择json格式进行传参即可。如果是json格式传参,我们需要把json转化成字符串类型,代码如下:
[javascript] view plain copy
这样,我们的ajax也就可以通过json格式进行传参了。现在的ajax完整代码和调用方式如下:
[javascript] view plain copy
现在这个Ajax基本上已经可以满足业务上的所以需求,不过还有一点没有实现,我们的Ajax不能设置请求头?!为了一些特殊需求的情况下,我们还是要把这一功能加上的:
[javascript] view plain copy
现在的完整代码入下:
[javascript] view plain copy
完整示例代码文件:JavaScript封装Ajax完整示例代码
jax指的是异步JavaScript和XML,是一套综合了多项技术的浏览器端网页开发技术。也是目前网页前端设计较为流行使用的技术。Ajax能够真正实现网页前端与业务后台的分离,体现出网页设计大前端的设计思想。所有的前端设计只需要通过Ajax将消息传递给业务逻辑,运算完直接发送前端。其实现原理如下:
工作原理及过程
一般情况下,在处理具体业务是网页通常采用发送HTTP请求中带有参数形式传递命令与数据,处理页面接收到数据之后进行处理。这种情况需要页面跳转或者页面刷新,增加了服务器与客户端通信的开销。而使用Ajax技术进行业务处理时只需要通过Ajax与Json实现在不刷新页面前提下完成业务功能,在满足前后端分离的基础上进一步降低网络通信量。本文针对初学者以实例形式对Ajax应用进行说明,希望对初学者有所帮助。
案例描述:前端为用户信息查询页面login.html,提供文本框用于接收用户姓名,业务逻辑处理页面为query.php,模拟接收用户姓名,执行查询,返回用户基本信息,前端login.html通过Ajax回调函数读取信息并以table形式进行输出显示。其前端页面设计如下:
前端测试页面
(1) XMLHttpRequest对象
XMLHttpRequest是 AJAX 的基础。用于向服务器发送request请求实现数据交换。由于是对象XMLHttpRequest在使用的时候需要用new进行对象的实例化。如:var xmlhttp = new XMLHttpRequest();
(2) 发送请求open()与send()
通过使用open与send方法将客户端Ajax请求发送到服务器端,其中open请求带有请求类型等参数,send可以带传递的参数值。两函数基本语法如下:
open(method,url,async)//方法、处理URL,异步/同步 send(string)//post类型时传递参数
(3) onreadystatechange 事件
通过使用该事件用于响应服务器端状态的改变,readyState与status,其中readyState=4表示服务器请求已完成,响应已就绪。status=200表示已就绪。因此可以在该事件响应函数中去接收服务端传递数据。
(4) 服务器返回值类型responseText与responseXML,其中responseText表示接收服务器发送过来的字符串。
(1)获取表单用户名值 var uname=document.getElementById('name').value;
(2)发送Ajax POST请求
Ajax Post请求
(3)(服务器请求处理)业务逻辑处理
php处理业务逻辑
(4)前端获取服务器值并输出显示表格
前端显示服务器发送数据(在不刷新页面情况下)
以上给出使用JavaScript原生态Ajax进行服务器与客户端浏览器进行数据交互的简单例题,重点为XMLHttpRequest对象的使用,业务逻辑处理使用了PHP。整体实现效果GIF动图描述如下:
Ajax实现效果
本头条号长期关注编程资讯分享;编程课程、素材、代码分享及编程培训。如果您对以上方面有兴趣或代码错误、建议与意见,可以联系作者,共同探讨。期待大家关注!如需案例完整代码请关注并私信,往期前端设计文章链接如下:
接:https://segmentfault.com/a/1190000017396192
AJAX即“Asynchronous Javascript And XML”,Ajax是一种异步请求数据的web开发技术,对于改善用户的体验和页面性能很有帮助。简单地说,在不需要重新刷新页面的情况下,Ajax 通过异步请求加载后台数据,并在网页上呈现出来。常见运用场景有表单验证是否登入成功、百度搜索下拉框提示和快递单号查询等等。Ajax的目的是提高用户体验,较少网络数据的传输量。同时,由于AJAX请求获取的是数据而不是HTML文档,因此它也节省了网络带宽,让互联网用户的网络冲浪体验变得更加顺畅。
在解释Ajax原理之前,我们不妨先举个“领导想找小李汇报一下工作”例子,领导想找小李问点事,就委托秘书去叫小李,自己就接着做其他事情,直到秘书告诉他小李已经到了,最后小李跟领导汇报工作。
Ajax请求数据流程与“领导想找小李汇报一下工作”类似。其中最核心的依赖是浏览器提供的XMLHttpRequest对象,它扮演的角色相当于秘书,使得浏览器可以发出HTTP请求与接收HTTP响应。浏览器接着做其他事情,等收到XHR返回来的数据再渲染页面。
理解了Ajax的工作原理后,接下来我们探讨下如何使用Ajax。
1.创建Ajax核心对象XMLHttpRequest(兼容性)
1. var xhr=null; 2. if (window.XMLHttpRequest) 3. {// 兼容 IE7+, Firefox, Chrome, Opera, Safari 4. xhr=new XMLHttpRequest(); 5. } else{// 兼容 IE6, IE5 6. xhr=new ActiveXObject("Microsoft.XMLHTTP"); 7. }
2.向服务器发送请求
1. xhr.open(method,url,async); 2. send(string);//post请求时才使用字符串参数,否则不用带参数。
注意:post请求一定要设置请求头的格式内容
xhr.open("POST","test.html",true); xhr.setRequestHeader("Content-type","application/x-www-form-urlencoded"); xhr.send("fname=Henry&lname=Ford"); //post请求参数放在send里面,即请求体
3.服务器响应处理(区分同步跟异步两种情况)
responseText 获得字符串形式的响应数据。
responseXML 获得XML 形式的响应数据。
①同步处理
1. xhr.open("GET","info.txt",false); 2. xhr.send(); 3. document.getElementById("myDiv").innerHTML=xhr.responseText; //获取数据直接显示在页面上
②异步处理
相对来说比较复杂,要在请求状态改变事件中处理。
1. xhr.onreadystatechange=function() { 2. if (xhr.readyState==4 &&xhr.status==200) { 3. document.getElementById("myDiv").innerHTML=xhr.responseText; 4. } 5. }
什么是readyState?
readyState是XMLHttpRequest对象的一个属性,用来标识当前XMLHttpRequest对象处于什么状态。
readyState总共有5个状态值,分别为0~4,每个值代表了不同的含义
什么是status?
HTTP状态码(status)由三个十进制数字组成,第一个十进制数字定义了状态码的类型,后两个数字没有分类的作用。HTTP状态码共分为5种类型:
常见的状态码
仅记录在 RFC2616 上的 HTTP 状态码就达 40 种,若再加上 WebDAV(RFC4918、5842)和附加 HTTP 状态码 (RFC6585)等扩展,数量就达 60 余种。接下来,我们就介绍一下这些具有代表性的一些状态码。
③GET和POST请求数据区别
关于第一点区别,详情见下面两张图:
其实XMLHttpRequest或者封装后的框架进行网络请求,这种方式已经有点老旧了,配置和调用方式非常混乱,近几年刚刚出来的Fetch提供了一个更好的替代方法,它不仅提供了一种简单,合乎逻辑的方式来跨网络异步获取资源,而且可以很容易地被其他技术使用。
*请认真填写需求信息,我们会在24小时内与您取得联系。