这是我写的第一篇文章,想一想还有点小激动呢。本着助人为乐的思想,认识了一些前端的初学者,帮助他们更快的步入到前端这个一个行业。今天呢,我想要说的主题是:工做中的先后端交互。前端
1.古老的表单提交 这种形式呢,比较早,之后端为主。前端提交表单,后端验证(jsp,request.getParameter(""))。这种方式后端作的比较多,我就不特别说明了。 2.AJAX的数据提交 这种形式呢,如今用的较多。后端基本就作接口,作权限,其余的都交由前端去完成。这个呢就是咱们今天主要说的。 3.表单和AJAX结合 适合的才是最好的。这点我深信不疑
常见的几种方式,我已经说明了。接下来咱们谈一谈咱们须要什么东西。
场景一:ajax
XXX:咱们公司要作接口,我要怎么办? LN:哦,接口文档发我看看。 XXX:什么是接口文档,我没有啊? LN:接口文档由四部分组成:(这个看我的习惯有的写得特别简陋,因此第一次的时候问清楚每一个参数意思) 1.接口地址 URL 2.请求方式 get/post 3.请求参数 page,pageNum 4.响应参数 state,list XXX:哦哦,这样啊,那我和他们要一下。 接口:/mvc/training/ge 请求:key,orderBy,begin,length LN:没给你响应,也没有给你请求方式啊。 1.给接口补全URL,域名/mvc/training/ge。 2.把你补全的URL,扔到浏览器的地址栏,看看返回的是什么。固然若是请求参数里面有必填项,那你要用URL?key=value&key2=value2的形式模拟get请求。 2.1 浏览器把服务器端的响应给你显示了出来。而后你对照这个问后端人员每一个是什么意思。 2.2 抛出405错误。这个就比较凄惨了。禁止get请求,那你有两种方式一个是下载一款软件能够模拟post请求,一个是直接写AJAX,而后改为post方式。 3.由上面咱们已经知道接口的四部分了,那咱们就要用ajax获取个人数据了. $.ajax({ url: "/mvc/training/ge",//请求接口 type: "POST",//请求方式 data: {key:1},//请求参数 dataType: "json",//响应类型 success: function(data, textStatus){//访问成功的回调函数,参数是响应,描述状态的字符串 console.log(data); }, error: function(XMLHttpRequest, textStatus, errorThrown){//访问失败的回调函数,参数是XMLHttpRequest对象、错误信息、捕获的错误对象(可选); } }); 我的大力推荐这个,第二步就能够省去了。success的console.log(data);也能够看到响应,完美的剧情。固然,你不要告诉我,你不会看控制台。 XXX:恩恩。好的。我试试去。
场景二:
XXX:这是个人接口。我要怎么作个人页面啊。逻辑怎么写。
LN:json
$.ajax( method:"GET",//对于请求类型 url:"/isNickName",//请求url,这个我抹黑了。直接复制过来就能够了 dataType: 'json', data: {nickName:$.trim($("#checktips").val())},//这个是一个验证是否重名的接口。参数只有一个 名字 ).done(function(data){ if(data.code == 0){//data.code的值这个是后端人员规定的。 console.log("请求成功"); if(data.object==1){//1为重复 console.log("这个nickName重复啦"); $("#retips").show(); }else if(data.object==0){ console.log("这个nickName不重复"); $("#retips").hide(); }else{ console.log("未知异常"); } }else if(data.code == -2){ console.log("你没有权限,一般来说,你是没有登陆"); }else if(data.code == -5){ console.log("参数错误哦。"); }else{ console.log(data.result); } }).fail(function(a,b,c){ console.log("接口出问题啦"); })
我简单的解释一下上面这个代码,.done()里面的代码确定每次都不同。因此说确定不能网上随便复制一个就能够,和公司的后端人员问清楚每个参数的做用意义,对于写代码是特别有帮助的。从接口文档能够看出,这我的后端十分的懒,我全部的参数都是访问了之后而后本身猜出来的。后端
场景有上面的两个,我以为已经能够了。就不在写了浏览器
文章的最后咱们来讲一下 调用 和 .done事件里面的代码 虽然这两个没有关系。服务器
1.调用 最简单的调用方法$(selector).on("click",function(){里面放刚才场景二的代码})。 可是咱们有的时候用的不是click. blur 失去焦点的时候触发 change 失去焦点而后判断是否改变,改变触发 keyDown keyup 按下抬起(这个是最好的,可是要用去抖,下一篇说) 2.done(function(){}) 这个里面通常来讲,就是咱们用获得的数据去和咱们的DOM节点作一些操做。这个每一个项目都不同。可是确定都和DOM的操做啦渲染啦有关。