Ajax:即异步的XML和Javascript,在不刷新和提交的情况下,页面局部更新,实现前后端分离。

Ajax的核心对象是XMLHttpRequest,服务器通过xhr对象与浏览器异步通信

关于HTTP协议:

请求部分(www.baidu.com

响应部分:

 

Content-Type, 请求消息:text/plain未经编码    application/x-www-form-urlencoded 编码后的表单数据(默认)  

                                    multipart/form-data  请求内容中包含数据的上传

           响应消息:text/plain    text/html  text/css   application/javascript    application/json   image/jpeg  等等mime标准

XHR的常用成员属性:

readyState:描述请求响应进行到了哪一步  取值{0:请求未发送 1:XHR打开请求连接  2:XHR接受到响应消息头部 3:加载响应主体 4加载完响应主体}       

status:响应状态码 需要readyState变成2才有值  2XX  3XX 4XX 5XX  304跳转  200响应成功

responseText:响应消息的主体数据   对应readyState 3->4

成员方法:

open(method, url, isAsync) 打开到服务器的连接  

onreadystatechange:状态改变(一般是监听,当readyState变为4时候,检测响应是否成功,在调用响应处理函数)

send( null/body ) 发送请求消息

setRequestHeader() 设置请求消息头部

getResponseHeader()   得到响应消息头部

 

XHR 发请求步骤: (具体事例见后面)

1)创建XHR对象 —— 每个XHR只能发一个请求

var xhr = new XMLHttpRequest();

(2)绑定监听函数,处理XHR的每一次状态改变

xhr.onreadystatechange = function(){ }

(3)打开到Web服务器的连接

xhr.open('GET','1.php', true);

(4)发送请求消息主体

xhr.send(null);    notice:get的消息在头部,作为属性参数传给后台,如果为post则请求消息在请求主体中

 

如果是post请求 需设置请求头 告诉服务器传的文件类型,否则服务器会无法解析此文件,点击会直接下载。。

xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');

 

关于网站优化Http方免考虑:减少DNS域名解析  使用持久链接  合理设置缓存时间 传送用压缩格式gzip 提高服务器运算速度等

json:是一种轻量级的字符串数据交换格式  等同于xml作用的一部分   JSON字符串只能有一个根元素 

相关API:$str = json_encode($list); php服务器端转化为json

JSON.parse( xhr.responseText ) 客户端解析为json

为了取代之前的 4步 5步请求法,JQuery提供了几个AJAX的操作函数

$('选择器').load( 'x.php' ,[data], [fn] ) 

xhr.responseText设置为当前选定元素的innerHTML        服务器返回的必须是html片段,响应内容会替换掉当前选定元素中已有的内容!

$.get( 'x.php' ,'uname=tom&age=20', function(txt, msg, xhr){  } )  回调函数 txt是响应内容  msg是status状态

$.post( 'x.php' ,'uname=tom&age=20', function(txt, msg, xhr){  } ) 创建XHR发起异步的POST请求,第二个参数是必需的请求数据(键值对形式或者对象形式)

$.getScript( 'x.php' ,[data], [fn])   要求服务器端返回的必须是application/javascript类型的响应   该方法会自动调用eval(xhr.responseText)进行执行

$.getJSON( 'x.php' ,[data],function(result, msg, xhr){  })    服务器端返回的必须是application/json类型的响应 客户端自动解析json为对象或者数组

都有局限性 无法处理响应错误 通用的是

$.ajax( {

type: 'GET', //POST/PUT/DELETE/HEAD

url: 'x.php',

data: 'k=v'或{k:v} //要提交的请求数据

beforeSend: fn, //请求发送之前的回调函数

success: fn, //响应成功的回调函数

error: fn, //响应失败的回调函数

complete: fn //响应完成的回调函数-不论成败

} )

 

等同于js xhr做法:

var xhr = new XMLHttpRequest()

xhr.onreadystatechange = function(){

  if(xhr.readyState===4){

      if(xhr.status===200){

success();

      }else {

 error();

      }

  complete();

  }

}

xhr.open('GET','x.php?k=v', true)

beforeSend();

xhr.send(null);

Ajax (一)的更多相关文章

  1. jQuery之ajax实现篇

    jQuery的ajax方法非常好用,这么好的东西,你想拥有一个属于自己的ajax么?接下来,我们来自己做一个简单的ajax吧. 实现功能 由于jq中的ajax方法是用了内置的deferred模块,是P ...

  2. Ajax及跨域

    概念 Ajax Ajax,Asynchronous JavaScript and XML,字面意思:异步的 JavaScript 和 XML,是指一种创建交互式网页应用的网页开发技术. 用于异步地去获 ...

  3. 一个粗心的Bug,JSON格式不规范导致AJAX错误

    一.事件回放  今天工作时碰到了一个奇怪的问题,这个问题很早很早以前也碰到过,不过没想到过这么久了竟然又栽在这里. 当时正在联调一个项目,由于后端没有提供数据接口,于是我直接本地建立了一个 json ...

  4. ABP文档 - Javascript Api - AJAX

    本节内容: AJAX操作相关问题 ABP的方式 AJAX 返回信息 处理错误 HTTP 状态码 WrapResult和DontWrapResult特性 Asp.net Mvc 控制器 Asp.net ...

  5. ajax异步请求

    做前端开发的朋友对于ajax异步更新一定印象深刻,作为刚入坑的小白,今天就和大家一起聊聊关于ajax异步请求的那点事.既然是ajax就少不了jQuery的知识,推荐大家访问www.w3school.c ...

  6. 调用AJAX做登陆和注册

    先建立一个页面来检测一下我们建立的用户名能不能用,看一下有没有已经存在的用户名吗 可以通过ajax提示一下 $("#uid").blur(function(){ //取用户名 va ...

  7. Ajax 概念 分析 举例

    Ajax是结合了访问数据库,数据访问,Jquery 可以做页面局部刷新或者说是页面不刷新,我可以让页面不刷新,仅仅是数据的刷新,没有频繁的刷页面,是现在比较常用的一种方式做页面那么它是怎么实现页面无刷 ...

  8. ajax

    常见的HTTP状态码状态码:200 请求成功.一般用于GET和POST方法 OK301 资源移动.所请求资源移动到新的URL,浏览器自动跳转到新的URL Moved Permanently304 未修 ...

  9. 学习笔记之MVC级联及Ajax操作

    由于刚转型到MVC,MVC的架构模式很多不是很清楚,比如今天就想做个级联的操作,因为之前的ASP.NET的方式是通过:控件-->添加事件-->后台编写级联事件进行触发,但是这个MVC就不同 ...

  10. javascript表单的Ajax 提交插件的使用

    Ajax 提交插件 form.js 表单的下载地址:官方网站:http://malsup.com/jquery/form/ form.js 插件有两个核心方法:ajaxForm()和ajaxSubmi ...

随机推荐

  1. ImageMagick and JMagick install on Mac OSX

    接的遗留代码,在本地运行,有jmagick-6.4.0.jar 但是出现错误: javax.servlet.ServletException: java.lang.NoClassDefFoundErr ...

  2. Dispatcher.Invoke方法

    前一篇小猪分享过在WPF中简单的使用BackgroundWorker完成多线程操作!在那篇中小猪利用了BackgroundWorker组件对耗时比较多的操作放在了单独的BackgroundWorker ...

  3. Grunt完成对LESS实时编译

    安装 安装grunt需要先安装node.js. 之后需要借助npm来安装grunt-cli,在cmd中npm install -g grunt-cli.(测试grunt --version看是否正确显 ...

  4. [Jquery]某宝图片轮播(无缝、带左右切换按钮)

    [效果] 左右移动(非渐隐) [思路] 1.结构与样式 ①最外层div盒子当容器,里面ul宽度无限大并且相对定位(到时候移动其实移的是ul的left) ②按钮的透明度可用background:rgba ...

  5. HDU 4939 Stupid Tower Defense (2014 Multi-University Training Contest 7)

    思路:首先红色肯定要放在最后面.前面蓝色和绿色dp求解. dp[i][j]  表示前面(i+j) 个 有 i 个蓝色塔  j个绿色塔 能造成最大伤害. //====================== ...

  6. swiper 内容超出纵向滚动 解决办法

    .swiper-slide { overflow: auto; }   var swiper = new Swiper('.swiper-container', { direction: 'verti ...

  7. iOS中FMDB的使用

    1在日常的开发中,我们需要用到离线缓存将数据信息存入数据库,在没有网络的时候进行加载,而我们IOS用的就是sqlite3数据库,用原生的sql我们也能实现,但是书写起来比较麻烦,尤其是其它语言转过来的 ...

  8. ssential Diagram for Windows FormsC#/winForm类似visio的拓扑图节点连线控件免费下载

    Essential Diagram for Windows Forms是一款可扩展的.高性能的.NET平台下的拓扑图控件,可用于开发像Microsoft Visio一样的交互式地绘图和图解应用程序,在 ...

  9. NSIS 的简介

    NSIS (Nullsoft Scriptable Install System)是一个Open Source的Windows系统下安装程序制作程序.它提供了安装.卸载.系统设置.文件解压缩等功能.这 ...

  10. OD调试篇6--对一些真正的小程序进行一点点的修改

    先打开这个程序看看,提醒你这是一个未注册版本的软件.会发现只能添加4个联系人,这显然是我不想看见的,于是我要对这个程序进行一些修改,嘿嘿... 通过OD载入这个程序 有一些(SEH)也就是异常,我们可 ...