轻松理解JavaScript之AJAX


Posted in Javascript onMarch 15, 2017

摘要

AJAX技术是网页构建的必备技能之一,本文希望能帮助大家轻松的学习这项技术

一、什么是ajax?

ajax(异步javascript xml) 能够刷新局部网页数据而不是重新加载整个网页。

二、如何使用ajax?

第一步:创建xmlhttprequest对象

创建xmlhttprequest对象,XMLHttpRequest对象用来和服务器交换数据。

var xmlhttp =new XMLHttpRequest();

第二步:注册回调函数

onreadystatechange函数,当服务器响应请求并返回数据后,我们想要客户端处理这些数据就需要使用onreadystatechange函数,每次xmlhttprequest对象的readyState发生改变都会触发onreadystatechange函数。对于readyState会在下一章节详细介绍。

xmlHttp.onreadystatechange= callback;
  function callback(){}

第三步:配置和发送请求

使用xmlhttprequest对象的open()和send()方法配置和发送资源请求给服务器。

xmlhttp.open(method,url,async) method包括get 和post,url主要是文件或资源的路径,async参数为true(代表异步)或者false(代表同步)

xmlhttp.send();使用get方法发送请求到服务器。

xmlhttp.send(string);使用post方法发送请求到服务器。

post表单数据需要使用xmlhttprequest对象的setRequestHeader方法增加一个HTTP头。

post 发送请求什么时候能够使用呢?

(1)更新一个文件或者数据库的时候。

(2)发送大量数据到服务器,因为post请求没有字符限制。

(3)发送用户输入的加密数据。

xhttp.open("POST", "ajax_test.aspx", true);
xhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xhttp.send("fname=Henry&lname=Ford");

第四步:处理响应数据

使用xmlhttprequest对象的responseText或responseXML属性获得服务器的响应。

使用responseText属性得到服务器响应的字符串数据,使用responseXML属性得到服务器响应的XML数据。

在回调函数中使用readyState==4和status==200判断交互是否结束,响应是否正确,并根据需要获取服务器端返回的数据,更新页面内容。

function callback(){
  if(xmlHttp.readyState == 4){
   //判断交互是否成功
   if(xmlHttp.status == 200){
    //获取服务器返回的数据
    //获取纯文本数据
    var responseText =xmlHttp.responseText;
    document.getElementById("info").innerHTML = responseText;
   }
  }
}

三、AJAX运行过程中5种状态(readyState)

在AJAX实际运行当中,对于访问XMLHttpRequest(XHR)时并不是一次完成的,而是分别经历了多种状态后取得的结果,对于这种状态在AJAX中共有5种,这五种状态是由AJAX引擎切换设置的,分别是。

0 : 定义了XHR,但还未初始化

1 :调用send()方法,正在发送请求,请求发送完毕后,开始等待接收响应

2 :响应接收完成

3 :正在解析响应内容

4 :响应内容解析完成,返回给客户端调用

对于上面的状态,其中“0”状态是在定义后自动具有的状态值,而对于成功访问的状态(得到信息)我们大多数采用“4”进行判断。

值得注意的是,状态每切换一次,都会触发onreadystatechange 事件,所以整个过程onreadystatechange 事件被触发5次

四、AJAX的优缺点

优点

1、最大的一点是页面无刷新,在页面内与服务器通信,不需要打断用户的操作,具有更加迅速的响应能力给用户的体验非常好。

2、减轻服务器的负担,ajax的原则是“按需取数据”,可以最大程度的减少冗余请求,和响应对服务器造成的负担。

缺点

1、ajax干掉了back按钮,即对浏览器后退机制的破坏。

2、对搜索引擎的支持比较弱。

 以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
JS字符串处理实例代码
Aug 05 Javascript
php的文件上传入门教程(实例讲解)
Apr 10 Javascript
Bootstrap3.0学习教程之JS折叠插件
May 27 Javascript
详解Vue2.x-directive的学习笔记
Jul 17 Javascript
AngularJS使用ui-route实现多层嵌套路由的示例
Jan 10 Javascript
centos 上快速搭建ghost博客方法分享
May 23 Javascript
element-ui使用导航栏跳转路由的用法详解
Aug 22 Javascript
全面解析vue router 基本使用(动态路由,嵌套路由)
Sep 02 Javascript
Angular6 正则表达式允许输入部分中文字符
Sep 10 Javascript
vue.js编译时给生成的文件增加版本号
Sep 17 Javascript
如何在基于vue-cli的项目自定义打包环境
Nov 10 Javascript
Map与WeakMap类型在JavaScript中的使用详解
Nov 18 Javascript
jQuery插件ContextMenu自定义图标
Mar 15 #Javascript
JavaScript对象引用与赋值实例详解
Mar 15 #Javascript
jQuery图片瀑布流的简单实现代码
Mar 15 #Javascript
JavaScript关联数组用法分析【概念、定义、遍历】
Mar 15 #Javascript
jQuery animate()实现背景色渐变效果的处理方法【使用jQuery.color.js插件】
Mar 15 #Javascript
js中的触发事件对象event.srcElement与event.target详解
Mar 15 #Javascript
jQuery动态产生select option下拉列表
Mar 15 #Javascript
You might like
一个简单的MySQL数据浏览器
2006/10/09 PHP
其他功能
2006/10/09 PHP
PHP产生随机字符串函数
2006/12/06 PHP
学习discuz php 引入文件的方法DISCUZ_ROOT
2009/06/21 PHP
php UTF8 文件的签名问题
2009/10/30 PHP
phpExcel导出大量数据出现内存溢出错误的解决方法
2013/02/28 PHP
php常用的工具开发整理
2019/09/26 PHP
javascript基础知识大全 便于大家学习,也便于我自己查看
2012/08/17 Javascript
6款经典实用的jQuery小插件及源码(对话框/提示工具等等)
2013/02/04 Javascript
使用javascript过滤html的字符串(注释标记法)
2013/07/08 Javascript
jquery的attr方法禁用表单元素禁用输入内容
2014/06/23 Javascript
页面加载完后自动执行一个方法的js代码
2014/09/06 Javascript
在for循环中length值是否需要缓存
2015/07/27 Javascript
jQuery实用技巧必备(下)
2015/11/03 Javascript
js贪吃蛇游戏实现思路和源码
2016/04/14 Javascript
微信开发 消息推送实现代码
2016/10/21 Javascript
AngularJS中transclude用法详解
2016/11/03 Javascript
JS作用域深度解析
2016/12/29 Javascript
js实现自动图片轮播代码
2017/03/22 Javascript
jQuery Plupload上传插件的使用
2017/04/19 jQuery
Angular.js中定时器循环的3种方法总结
2017/04/27 Javascript
JavaScript中的this/call/apply/bind的使用及区别
2020/03/06 Javascript
vue+canvas实现移动端手写签名
2020/05/21 Javascript
vue结合el-upload实现腾讯云视频上传功能
2020/07/01 Javascript
VUE实现吸底按钮
2021/03/04 Vue.js
python实现类似ftp传输文件的网络程序示例
2014/04/08 Python
Pytorch 实现自定义参数层的例子
2019/08/17 Python
使用python 对验证码图片进行降噪处理
2019/12/18 Python
借助Paramiko通过Python实现linux远程登陆及sftp的操作
2020/03/16 Python
CSS3实现的炫酷菜单代码分享
2015/03/12 HTML / CSS
HTML5 canvas画图并保存成图片的jcanvas插件
2014/01/17 HTML / CSS
Ajax请求总共有多少种Callback
2016/07/17 面试题
美术毕业生求职信
2014/02/25 职场文书
2014年清明节寄语
2014/04/03 职场文书
财务工作犯错检讨书
2014/10/07 职场文书
2019年七夕情人节浪漫祝福语大全!
2019/08/08 职场文书