Ajax基础--JavaScript实现
ajax原理
1、ajax
即“Asynchronous JavaScript and XML”(异步 JavaScript 和 XML),也就是无刷新数据读取。
通俗地讲就是:AJAX 通过在后台与服务器交换少量数据的方式,允许在不重新加载整个页面的情况下,对网页的一部分内容进行数据更新。
2、http 请求
http(超文本传输协议)是一个基于请求与响应模式的、无状态的、应用层的协议。
这里需要了解 http 请求的两个方法:GET方法 和 POST方法。
①、GET 用于获取数据。GET 是在 URL 中传递数据,它的安全性低,容量低。
②、POST 用于上传数据。POST 安全性一般,容量几乎无限。
PS:有兴趣的同学可以参考Http协议详解
3、XMLHttpRequest
XMLHttpRequest 是一个用于在后台与服务器交换数据的对象。目前几乎所有浏览器支持该对象。
XMLHttpRequest是ajax技术的核心部分,在javascript中就是利用XMLHttpRequest对象来实现ajax功能,以便给用户带来好的体验,其他的方法实现ajax功能也都是实现此功能。
XMLHttpRequest常用的方法、属性:
①、open()方法:用于向服务器发送一个请求;该方法有3个参数,第一个参数表示发送请求的方式(即连接服务器的方式)即“GET”或“POST”,第二个参数表示要请求的URL地址,第三个参数表示是否以异步方式发出请求,若为true则表示是异步,否则为同步。
②、send()方法:发送请求。
③、onreadystatechange 事件:紧跟其后是一个函数名或是一个匿名函数,发送请求以后XMLHttpRequest对象一直处于等待状态,直到服务器响应后激发 onreadystatechange事件,紧跟其后的方法就是当XMLHttpRequest对象的onreadystatechange事件激发之后 的客户端方法。
④、readyState属性:XMLHttpRequest对象的请求状态,返回的是整数(0-4),具体意思如下:
0(未初始化):还没有调用 open() 方法。
1(载入):已调用 send() 方法,正在发送请求。
2(载入完成):send() 方法完成,已收到全部响应内容。
3(解析):正在解析响应内容。
4(完成):响应内容解析完成,可以在客户端调用。
⑤、status:请求结果,返回 200 或者 404。
200 => 成功。
404 => 失败。
⑥、responseText:返回内容,即我们所需要读取的数据。注意:responseText 返回的是字符串。
实现例子
1、创建 ajax 对象
在创建对象时,要考虑浏览器兼容性问题,即IE浏览器和非IE浏览器(如firefox、chrome等):
var ajaxObj=null;
if(window.XMLHttpRequest){
ajaxObj = new XMLHttpRequest();//IE6以上及非IE浏览器
}else if(window.ActiveXObject){
ajaxObj = new ActiveXObject('Microsoft.XMLHTTP');//IE6以下的IE浏览器
}else{
throw new Error('no ajax object available.');
}
2、连接服务器
这里就用上面讲到的open方法。
ajaxObj.open('GET',URL,true);
3、发送请求
ajaxObj.send();
4、接受数据
ajaxObj.onreadystatechange=function(){
if(ajaxObj.readyState==4){
if(ajaxObj.status==200){
funSucc(ajaxObj.responseText);//funSucc是获取成功时处理的函数
}else{
if(funFaild){
funFaild();//funFaild是获取失败时处理的函数
}
}
}
};
将以上代码连起来:
function ajax(url, funSucc, funFaild){
//1.创建ajax对象
var ajaxObj = null;
if(window.XMLHttpRequest){
ajaxObj = new XMLHttpRequest();
}else if(window.ActiveObject){
ajaxObj = new ActiveXObject("Microsoft.XMLHTTP");
}else{
throw new Error('no ajax object available.')
}
//2.连接服务器
ajaxObj.open('GET', URL, true);//open(方法, url, 是否异步)
//3.发送请求
ajaxObj.send();
//4.接收返回
ajaxObj.onreadystatechange = function(){ //OnReadyStateChange事件
if(ajaxObj.readyState == 4){ //4为完成
if(ajaxObj.status == 200){ //200为成功
funSucc(ajaxObj.responseText)
}else{
if(funFaild){
funFaild();
}
}
}
};
}
最后是一个简单实例:
<!DOCTYPE HTML>
<html>
<head>
<title>ajax基础</title>
</head>
<body>
点击按钮的时候,读取abc.txt<input id="btn" type="button" value="读取"/><br/>
<div id="con"></div>
</body>
</html>
<script type="text/javascript" src="ajax.js"></script>
<script type="text/javascript">
window.onload = function(){
var oBtn = document.getElementById('btn');
var oCon = document.getElementById('con');
oBtn.onclick = function(){
ajax('abc.txt',function(str){
oCon.innerHTML = str;
});
}
}
</script>
abc.txt 内容:
这是ajax调用的内容1。
这是ajax调用的内容2。
这是ajax调用的内容3。
总结:
利用纯javascript实现ajax效果的主要步骤如下:
1、根据浏览器类型实例化XMLHttpRequest对象
2、利用XMLHttpRequest对象向服务器发出一个动态请求
3、编写XMLHttpRequest对象接收服务器的响应时要执行客户端代码,在客户端做一些设置来响应客户端操作
4、编写服务器方法,用于处理客户端请求并作出响应。
Ajax基础--JavaScript实现的更多相关文章
- 【Java EE 学习 31】【JavaScript基础增强】【Ajax基础】【Json基础】
一.JavaScript基础增强 1.弹窗 (1)使用window对象的showModelDialog方法和showModelessDialog方法分别可以弹出模式窗口和非模式窗口,但是只能在IE中使 ...
- 【javascript】ajax 基础
什么是 ajax ajax 即“Asynchronous JavaScript and XML”(异步 JavaScript 和 XML),也就是无刷新数据读取. http 请求 首先需要了解 htt ...
- 史上最全的Ajax基础详解
同步请求和异步请求 先解释一下同步和异步的概念: 同步是指:发送方发出数据后,等接收方发回响应以后才发下一个数据包的通讯方式. 异步是指:发送方发出数据后,不等接收方发回响应,接着发送下个数据包的通讯 ...
- 【Ajax 基础学习】
http://www.cnblogs.com/guduoduo/p/3681296.html 今天简单的学习了 Ajax 的基础知识,总结在这里.部分代码不是原创,特此说明. [Ajax 简介] AJ ...
- Ajax基础知识《一》
对于网站开发人员,一定不会陌生的Ajax技术,本篇就让我们认识一下它,或许在日后的开发过程中我们就可以使用到.Ajax在那方面使用的比较多呢?答案:表单注册,传统的表单注册,有时需要填写大量的信息,当 ...
- Ajax基础2
什么是服务器 网页浏览过程的分析 如何配置自己的服务器程序(AMP) 什么是Ajax 无刷新数据读取 异步,同步 Ajax基础(2) 使用Ajax 基础请求显示txt的文件 字符集编码 缓存,阻止缓存 ...
- ajax基础语法、ajax做登录、ajax做用户名验证是否可用、ajax做关键字查询动态显示、ajax做用表格显示数据并增加操作列
AJAX: AJAX 是一种用于创建快速动态网页的技术. 通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新.这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新. ...
- 【转】Ajax 基础学习
今天简单的学习了 Ajax 的基础知识,总结在这里.部分代码不是原创,特此说明. [Ajax 简介] AJAX = Asynchronous JavaScript and XML(异步的 JavaSc ...
- jQuery基础---Ajax基础教程(二)
jQuery基础---Ajax进阶 内容提纲: 1.加载请求 2.错误处理 3.请求全局事件 4.JSON 和 JSONP 5.jqXHR 对象 发文不易,转载请注明出处! 在 Ajax 基础一篇中, ...
随机推荐
- Bzoj 2763: [JLOI2011]飞行路线 拆点,分层图,最短路,SPFA
2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1694 Solved: 635[Submit][Statu ...
- lightoj1051 Good and Bad (dp)
题目链接:http://lightoj.com/volume_showproblem.php?problem=1051 题目大意:给你一个字符串,只包含大写字母和‘?’,如果字符串中出现了连续三个以上 ...
- DataGridView 列大写、列只能输入数字 分类: DataGridView 2014-12-07 08:40 332人阅读 评论(0) 收藏
列大写: 说明:调用EditingControlShowing事件 private void dgvGoods_EditingControlShowing(object sender, DataGri ...
- 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(35)-文章发布系统②-构建项目
原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(35)-文章发布系统②-构建项目 注:阅读本文,需要阅读本系列的之前文章 代码生成器下载地址(文章开头处) ...
- Newtonsoft.Json 与 DataTable的相互转换
1.这里下载:http://www.newtonsoft.com/products/json/ 安装: 解压下载文件,得到Newtonsoft.Json.dll 在项目中添加引用 2.引入 ...
- 树莓派做AP发射wifi(RTL8188CUS芯片) 分类: shell ubuntu Raspberry Pi 2014-11-29 01:25 822人阅读 评论(0) 收藏
最近在做一个项目,需要用树莓派作为AP发射wifi,对比cubieboard,树莓派的配置容易得多,而且支持也更多. 较为官方的介绍配置为无线热点的文章莫过于这一篇<RPI-Wireless-H ...
- zedboard--交叉编译Opencv库的生成 分类: shell ubuntu fool_tree的笔记本 ZedBoard OpenCV 2014-11-08 18:57 171人阅读 评论(0) 收藏
Opencv的移植,xzyfeixiang和rainysky的博客. 第一步肯定是下载opencv的源码包 第二步已经做好的交叉编译环境. 第三步下载安装cmake apt-get install ...
- 系统调用和中断处理的异同(以Linux MIPS为例)
在Linux下写一个驱动时候遇到的读操作性能问题,让我想一窥系统调用的处理流程,以查出问题的root cause.很多书把它和中断处理放在一起讲,但是又没有哪本书说清楚了,看来只有代码才能说明一切.以 ...
- systemTAP 学习
http://blog.csdn.net/moonvs2010/article/category/1570309
- async 与 await异步编程活用基础
[本文转自:http://www.cnblogs.com/x-xk/archive/2013/06/05/3118005.html 作者:肅] 好久没写博客了,时隔5个月,奉上一篇精心准备的文章,希 ...