《AJax - Async Javascript and xml - 异步的JavaScript和XML》

一、基础认识

AJax技术的目的:实现页面无刷新数据动态更改

优点: 

  + 不需要插件支持

  + 提供WEB程序的功能

  + 优秀的用户体验

  + 减轻服务器带宽的负担

缺点:

  + 破坏浏览器的前进与后退

  + 搜索引擎SEO的支持性不好

二、代码示例

学习后编写的一个很基础的Ajax函数,帮助自己更好的掌握Ajax

/*
* method => Ajax请求所采用的方法,GET或POST
* URL => 所要请求页面的URL
* paras=> 发送时附加的参数
* callback => 完成请求或页面数据准备完毕时执行的方法
*/ function Ajax(method,url,paras,callback){ function getXMLHttpReq(){
var XMLHttpReq = null;
if(window.XMLHttpRequest){
XMLHttpReq = new XMLHttpRequest();
}else if(window.ActiveXObject){
XMLHttpReq = new ActiveXObject('Microsoft.XMLHTTP');
}
return XMLHttpReq;
}
xhr = getXMLHttpReq(); if(method ==='POST'){
xhr.open('POST',url,true);
xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
if(paras!=''){
xhr.send(paras);
}else{
xhr.send(null);
}
}else{
if(paras!=''){
url = encodeURI(url+'?'+paras);
}
xhr.open('GET',url,true);
xhr.send(null);
} xhr.onreadystatechange=function(){
if(xhr.readyState==4&&xhr.status==200){
callback();
}
}
} //调用方法
function Ajax1(){
Ajax('GET','test.php','',function(){
document.getElementById('responseText').innerHTML = xhr.responseText;
})
}

· 代码说明:

ActiveXObject  //  利用ActiveX插件可以与微软的其它组件进行交换,包括这里我需要的微软自带的HTTP请求方法。

new ActiveXObjcet('Microsoft.XMLHTTP') // IE5/6支持的HTTP请求方法
xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
//如果Ajax请求是通过POST方式,那么为了方便后台通过键值对的形式获取数据,可以指定数据的发送以表单的形式。
open('GET','index.php?a=1&b=2',true)  //GET方式,通过在URL附加参数进行数据的传输。

XMLHttpReq.send(pars)  //POST方式的数据发送
url = encodeURI(url+'?'+pars);
//为了解决IE6/7在GET方式下传输中文参数出现乱码的情况,会在参数传输之前利用JS进行URL编码。 echo urldecode($_GET['a'])
// 客户端进行编码,服务端进行解码

· 重点讲解:

  1. readyState && status

   readyState表示HTTP请求的运行状态,不论请求的数据是否找到,都会经历以下的过程:

    0 ----  请求未初始化

    1 ----  与服务器建立连接

    2 ---- 请求已经接收

3 ---- 请求正在处理

   status 则表示了HTTP所请求数据的状态[常见的反馈码]:

    200 ---- 数据请求完成,已经可以使用。

    404 ---- 页面未找到。

  2. open()

    功能:初始化请求的参数。

    格式:open('请求数据的方式','所要请求的页面URL','是否异步');

    格式说明:

         · 请求数据的方式:GET | POST

         ·  是否异步:true(异步) | false(同步)

    * 如果存在setRequestHeader()方法,一定要把open()方法放在它之前的一行。

  3. send()

    功能:发送请求。

    格式:send(paras)

    代码示例:

send(null)

 //在GET方式下用这种方式,因为参数会附加在URL后进行传输。

send('fname=神&lname=经病') 

 //在POST方式,用这种方式传输参数,但要记得使用setRequestHeader()方法

  

  4. 同步与异步

    xmlHttpReq对象的open()方法第三个参数可以设置同步或异步的方式。

    true - 表示为异步,它不会等待服务器的执行完成。

    false - 表示同步,它会等待服务器执行完成,否则便会挂起程序,一直等待,一般不推荐是用同步的方式,不过对于一些小程序还是可以使用的。

  

  5.  setRequestHeader()

     该方法可以设置请求的头部信息,常用以post方式向一个动态网页文件提交数据时使用。这

    是因为PHP中的$_POST['key']方法,需要用到键值对的格式,因此必须声明请求的类型为: setRequestHeader('Content-Type','application/x-www-form-urlencoded') 以表单提交数据的方式来发送数据到服务器。

    

  6. 使用时间戳或随机数来确保无缓存的请求数据

    

//时间戳
open('GET','index.php?t='+ new Date()*1,true) //随机数
open('GET','index.php?m='+ Math.random(),true)

Ajax 学习 - 基础学习的更多相关文章

  1. Redis学习---基础学习[all]

    什么是NoSQL型数据库 NoSQL数据库---NoSQL数据库的分类 Redis学习---NoSQL和SQL的区别及使用场景 Redis学习---负载均衡的原理.分类.实现架构,以及使用场景 什么是 ...

  2. Ajax全面基础学习(二)

    两种配置ajax的方式 $.ajax('url',{ 配置ajax}); $.ajax({ url : 'url' 其他ajax配置}) ajax的回调函数 $.ajax('url',{ //请求成功 ...

  3. Ajax全面基础学习(一)

    快捷方法: $.get(url,[data],[callback],[type])get方法的[data]将被链在url后面[callback]是请求成功后的回调,可以得到响应数据,如果请求失败,看不 ...

  4. Android开发学习——基础学习

    在微信公众号上,发现一个自学android的一个文章,觉得不错.对其进行小小总结,整理给大家. 1. 基础UI学习 Button/TextView/EditText/CheckBox/ImageVie ...

  5. java 学习基础学习单词及java关键词

    在JAVA学习中我们难免会犯一些逻辑错误,语法错误,和一些运行错误,对于英语不好的人,就的记下下面的2常用单词,有助于我们提高在使用软件编写代码的速度和代码调试,能更便捷的找出错误,知道1中的保溜关键 ...

  6. ajax基础学习

    AJAX即"Asynchronous JavaScript and XML",意思是异步JavaScript和XML,是指一种创建交互式网页的网页开发技术. 虽然现在很少有人去自己 ...

  7. 【Ajax 基础学习】

    http://www.cnblogs.com/guduoduo/p/3681296.html 今天简单的学习了 Ajax 的基础知识,总结在这里.部分代码不是原创,特此说明. [Ajax 简介] AJ ...

  8. 【转】Ajax 基础学习

    今天简单的学习了 Ajax 的基础知识,总结在这里.部分代码不是原创,特此说明. [Ajax 简介] AJAX = Asynchronous JavaScript and XML(异步的 JavaSc ...

  9. ASP.NET MVC基础学习

    ASP.NET MVC基础学习 传统的MVC概念 模型:组类,描述了要处理的数据以及修改和操作数据的业务规则 视图:定义应用程序用户界面的显示方式 控制器:一组类,用来处理来自用户,整个应用程序流以及 ...

随机推荐

  1. 【腾讯Bugly干货分享】微信Tinker的一切都在这里,包括源码(一)

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57ecdf2d98250b4631ae034b 最近半年以来,Android热补 ...

  2. Java多线程21:多线程下的其他组件之CyclicBarrier、Callable、Future和FutureTask

    CyclicBarrier 接着讲多线程下的其他组件,第一个要讲的就是CyclicBarrier.CyclicBarrier从字面理解是指循环屏障,它可以协同多个线程,让多个线程在这个屏障前等待,直到 ...

  3. 与webview打交道中踩过的那些坑

    随着HTML5被越来越多的用到web APP的开发当中,webview这一个神器便日渐凸显出重要地位.简要的说,webview能够在移动应用中开辟出一个窗口,在里面显示html页面,css以及js代码 ...

  4. java提高篇(一)-----理解java的三大特性之封装

    从大二接触java开始,到现在也差不多三个年头了.从最基础的HTML.CSS到最后的SSH自己都是一步一个脚印走出来的,其中开心过.失落过.寂寞过.虽然是半道出家但是经过自己的努力也算是完成了“学业” ...

  5. SignalR + KnockoutJS + ASP.NET MVC4 实现井字游戏

    1.1.1 摘要 今天,我们将使用SignalR + KnockoutJS + ASP.NET MVC实现一个实时HTML5的井字棋游戏. 首先,网络游戏平台一定要让用户登陆进来,所以需要一个登陆模块 ...

  6. Java枚举类型getClass和getDeclaringClass区别(未完待续)

    Java中的枚举类型有getClass()和getDeclaringClass()两个方法,在通常情况下这两个方法返回的类型一样,在某些场景下会有不同的表现 参照 http://stackoverfl ...

  7. ios NSLog常见使用

    NSLog常见输出格式 Table 1  Format specifiers supported by the NSString formatting methods and CFString for ...

  8. CentOS 6.6下Redis安装配置记录

    转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/120.html?1455855209 在先前的文章中介绍过redis,以下 ...

  9. EF架构~CodeFirst自关联表的插入

    回到目录 这个文章对之前EF的一个补充,对于一些自关联表的添加,如果你建立了表约束确实有这种问题,一般主键为整形自增,父ID为可空,这时,在添加时如果不为ID赋值,结果就会出错. 错误: 无法确定依赖 ...

  10. 移动端基于HTML模板和JSON数据的JavaScript交互

    写本文之前,我正在做一个基于Tab页的订单中心: 每点击一个TAB标签,会请求对应状态的订单列表.之前的项目,我会在js里使用 +  连接符连接多个html内容: var html = ''; htm ...