记录自己对ajax\的理解,

首先要明白ajax是为了解决什么问题,简单来讲就是为了局部刷新页面,而不刷新整个界面。就比如现在有一个实时热度的显示,它是不断变化的,所以你肯定要不停的从数据库当中获取热度,进行显示,但是又只是更新热度,没有必要更新整个界面。这时候就用到了ajax,不断的向服务器发送请求,获取热度,之后使用js更新指定元素。那js是怎样更新的呢?

昂,其实直接用jquery就可以了,不过还是学习ajax肯定要对它具体是怎么实现的学习一下呀~

ajax用了  XMLHttpRequest,js,css,dom,xml等技术来实现,说下其中两个:

XMLHttpRequest:js里面的一个对象,能够进行连接服务器,发送请求等操作,可以理解为一个载体,我们所有的操作最终都是由他执行的。

xml:一种语言,其实跟html撒的差不多,只不过它是用来描述结构化数据的的格式,相当于就是存储交换的数据的一种格式,可扩展性更强一些,有它独特的数据结构格式。

下面来看看他的具体步骤吧:分为以下:

1.构建XMLHttpRequest对象

2.设置回调函数

3.和服务器创建连接

4.发送请求

1.构建XMLHttpRequest对象

这一步需要注意的就是ie浏览器和其他浏览器的创建方式的不同,普通浏览器直接创建该对象,而ie浏览器创建ActiveObject对象,并设置响应的参数,代码如下, 很容易理解

    if(window.XMLHttpRequest){    //非Ie浏览器
this.req = new XMLHttpRequest();
}else if(window.ActiveXObject){
this.req = new ActiveXObject("Microsoft.XMlHTTP");
}

,创建结束之后,我们就需要调用该对象的方法来完成异步请求了,我们会用到它的open和send方法,

open("method","url",【asyncFlag】,【username】,【password】);

method:请求的方式,get或者post

后面三个为可选参数,asynvFlag 表示是否异步请求,一般是true

send(params);

将当前连接中的请求发送给服务器,异步的直接返回,同步的话等待响应结束再返回,params是参数,post请求时候用的,另外注意,发送post请求时,要使用  setRequestHeader("Content-Type","application/x-www-form-urlencoded");设置请求头参数

还有他的4个属性:

readyState: 请求的状态,从0-4 依次表示:未初始化,加载中,加载完毕,交互中,完成

status: 服务器返回的Http状态码,

responseText,responseXML:服务器返回的内容,xml格式或者字符串格式的,json也可以返回

2.指定回调函数:

回调函数,顾名思义,就是服务器处理完请求之后执行的函数,相当于具体的业务逻辑函数。

XMLHttpRequest.onreadystatechange = 函数名;

这里注意一点:如果是该函数有参数,这样写:

..... = function(){ 函数名(params)};

3.建立与服务器的连接

使用open()函数就行,url就是你请求的服务器地址

4.发送请求,

直接send(null),post请求的话使用send(params),params的格式就是   变量名=具体值&变量名=具体值,这样的,用&分隔

所以呢,整体来讲还是比较容易理解的,下面是一个完整的示例:

var net  = new Object();
//构造函数
net.AjaxRequest = function (url, onload, onerror, method, params) {
this.req = null;
this.onload = onload;
this.method = method;
this.onerror = (onerror)? onerror :this.defaultError;
this.loadDate(url ,method, params); //有了这一步所以才能创建实例就进行ajax交互 }
//初始化对象并指定处理函数的方法,prototype添加新的属性
net.AjaxRequest.prototype.loadDate=function (url,method,params) {
if(!method){
method="GET";
}
if(window.XMLHttpRequest){ //非Ie浏览器
this.req = new XMLHttpRequest();
}else if(window.ActiveXObject){
this.req = new ActiveXObject("Microsoft.XMlHTTP");
}
if(this.req){
try{
var loader = this;
this.req.onreadystatechange = function () {//指定回调函数
net.AjaxRequest.onReadyState.call(loader); //call就是说让onReadyState这个函数来执行this对象的函数
}
this.req.open(method, url ,true); //创建连接
if(method == "POST"){ //post\请求设置请求头
this.req.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
}
this.req.send(params); //发送信息 }catch (e) {
this.onerror.call(this);
}
}
} //重构回调函数
net.AjaxRequest.onReadyState = function(){
var req = this.req;
var readyState = req.readyState;
if(readyState == 4){
if(req.status == 200){
this.onload.call(this);
}else{
this.error.call(this);
}
}
} //重构默认错误处理函数
net.AjaxRequest.prototype.defaultError = function(){
alert("错误数据,回调状态:"+this.req.readyState+",状态:"+this.status);
}

然后我们使用的时候,构建一个 net.AjaxRequest = function (url, onload, onerror, method, params) ,以这个为借口,并且将url,onload等几个参数重构一下就好,能够创建对象就实现ajax交互的原因,是我们在构造函数里面使用了

this.loadDate(url ,method, params); ,这个函数其实就是将我们ajax的所有具体操作整合在了一起,

对回调函数解释一下流程:

首先明白 a.call(b) 函数是让a函数来执行b函数,相当于就是让a函数接收b函数的参数,然后执行b的工作,两个字:重构

net.AjaxRequest.onReadyState.call(loader);  这句话 指定了回调函数为onReadyState,

之后这句代码   this.onload.call(this); 就是让传入的onload函数来重构当前this所指的函数,这里this指的就是回调函数

这块重构过来重构过去就是为了代码更加明了一些吧应该,不过我感觉更加不清晰了,

具体使用时候,

va loader = new net.AjaxRequest(url,回调函数,错误处理函数,请求方法,其他参数..):

之后每隔指定时间,或者根据具体规则来执行该语句就可以啦,

ajax具体实现学习记录的更多相关文章

  1. vue.js学习记录

    vue.js学习记录 文章已同步我的github笔记https://github.com/ymblog/blog,欢迎大家加star~~ vue实例 生命周期 beforeCreate:不能访问thi ...

  2. 【jQuery】精细学习记录

    [jQuery]精细学习记录 基础 基本语法: $(选择器).action(回调函数); $/jQuery //jQuery核心函数 $(选择器) //获得的jQuery对象 jQuery核心 - j ...

  3. Quartz 学习记录1

    原因 公司有一些批量定时任务可能需要在夜间执行,用的是quartz和spring batch两个框架.quartz是个定时任务框架,spring batch是个批处理框架. 虽然我自己的小玩意儿平时不 ...

  4. Java 静态内部类与非静态内部类 学习记录.

    目的 为什么会有这篇文章呢,是因为我在学习各种框架的时候发现很多框架都用到了这些内部类的小技巧,虽然我平时写代码的时候基本不用,但是看别人代码的话至少要了解基本知识吧,另外到底内部类应该应用在哪些场合 ...

  5. Apache Shiro 学习记录4

    今天看了教程的第三章...是关于授权的......和以前一样.....自己也研究了下....我觉得看那篇教程怎么说呢.....总体上是为数不多的精品教程了吧....但是有些地方确实是讲的太少了.... ...

  6. UWP学习记录12-应用到应用的通信

    UWP学习记录12-应用到应用的通信 1.应用间通信 “共享”合约是用户可以在应用之间快速交换数据的一种方式. 例如,用户可能希望使用社交网络应用与其好友共享网页,或者将链接保存在笔记应用中以供日后参 ...

  7. UWP学习记录11-设计和UI

    UWP学习记录11-设计和UI 1.输入和设备 通用 Windows 平台 (UWP) 中的用户交互组合了输入和输出源(例如鼠标.键盘.笔.触摸.触摸板.语音.Cortana.控制器.手势.注视等)以 ...

  8. UWP学习记录10-设计和UI之控件和模式7

    UWP学习记录10-设计和UI之控件和模式7 1.导航控件 Hub,中心控件,利用它你可以将应用内容整理到不同但又相关的区域或类别中. 中心的各个区域可按首选顺序遍历,并且可用作更具体体验的起始点. ...

  9. UWP学习记录9-设计和UI之控件和模式6

    UWP学习记录9-设计和UI之控件和模式6 1.图形和墨迹 InkCanvas是接收和显示墨迹笔划的控件,是新增的比较复杂的控件,这里先不深入. 而形状(Shape)则是可以显示的各种保留模式图形对象 ...

随机推荐

  1. linux 安装 websocketd

    1.下载 wget https://github.com/joewalnes/websocketd/releases/download/v0.3.0/websocketd-0.3.0-linux_am ...

  2. OSI参考模型---网络基础篇(1)

    什么是网络 网络就是将分布在不同地理位置,具有独立功能的终端(一切联网的设备都叫终端:例如电脑,手机,智能家电等等联网的设备),通过通信线路(双绞线.光纤.电话线等等)和通信设备(例如:交换机.路由器 ...

  3. BZOJ 2460:元素(贪心+线性基)

    题目链接 题意 中文题意 思路 线性基学习 题目要求选价值最大的并且这些数异或后不为0,可以考虑线性基的性质:线性基的任意一个非空集合XOR之和不会为0.那么就可以贪心地对价值从大到小排序,加入线性基 ...

  4. POJ 3621:Sightseeing Cows(最优比率环)

    http://poj.org/problem?id=3621 题意:有n个点m条有向边,每个点有一个点权val[i],边有边权w(i, j).找一个环使得Σ(val) / Σ(w)最大,并输出. 思路 ...

  5. AD域和LDAP协议

    随着我们的习大大上台后,国家在网络信息安全方面就有了很明显的改变!所以现在好多做网络信息安全产品的公司和需要网络信息安全的公司都会提到用AD域服务器来验证,这里就简单的研究了一下! 先简单的讲讲AD域 ...

  6. Azure中国CDN全球覆盖功能初探

    在不久前的4月初,Azure中国官网上简短地发布了其CDN中“标准版 Zone 2”功能.一开始笔者尚有些摸不着头脑,这个“Zone 2”具体指的是什么呢?好在后来官网更新了信息描述如下: 这下就比较 ...

  7. Impala集成C3P0的连接方式

    1. 概述 Impala是Cloudera公司主导开发的新型查询系统,它提供SQL语义,能查询存储在Hadoop的HDFS和HBase中的PB级大数据.已有的Hive系统虽然也提供了SQL语义,但由于 ...

  8. java接口自动化(一) - 接口自动化测试整体认知 - 开山篇(超详解)

    简介 了解什么是接口和为什么要做接口测试.并且知道接口自动化测试应该学习哪些技术以及接口自动化测试的落地过程.其实这些基本上在python接口自动化的文章中已经详细的介绍过了,不清楚的可以过去看看.了 ...

  9. 上传文件不落地转Base64字符串

    1. 问题描述 因需调用第三方公司的图像识别接口,入参是:证件类型.图像类型.图片base64字符串,采用http+json格式调用. 本来采用的方式是:前端对图片做base64处理,后端组装下直接调 ...

  10. 【题解】P1892 [BOI2003]团伙-C++

    原题传送门 前置知识:并查集,不会的补了再来. 这道题只是在并查集的基础上多了一个操作而已. 这种操作,叫做反集(就先这么叫着) 题目里有一种关系是互为朋友,这很好理解,把互为朋友的两个点合并就可以了 ...