js原生Ajax的封装和原理详解


Posted in Javascript onMarch 11, 2017

原理及概念

AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是一种用于创建快速动态网页的技术。

动态网页:是指可以通过服务器语言结合数据库随时修改数据的网页。

静态网页,随着html代码的生成,页面的内容和显示效果就基本上不会发生变化了——除非你修改页面代码。

AJAX = 异步 JavaScript和XML(标准通用标记语言的子集)。

AJAX 是与服务器交换数据并更新部分网页的艺术,在不重新加载整个页面的情况下。

Ajax的优势

AJAX 在浏览器与 Web 服务器之间使用异步数据传输(HTTP 请求),这样就可使网页从服务器请求少量的信息,而不是整个页面。

AJAX 可使因特网应用程序更小、更快,更友好。

AJAX 是一种独立于 Web 服务器软件的浏览器技术。

AJAX 基于下列 Web 标准:

JavaScriptXMLHTMLCSS在 AJAX 中使用的 Web 标准已被良好定义,并被所有的主流浏览器支持。AJAX 应用程序独立于浏览器和平台。

Web 应用程序较桌面应用程序有诸多优势;它们能够涉及广大的用户,它们更易安装及维护,也更易开发。

不过,因特网应用程序并不像传统的桌面应用程序那样完善且友好。

通过 AJAX,因特网应用程序可以变得更完善,更友好。

Ajax的异步

异步:是相对于同步而言的,我们学过的定时器也是异步的一种,也就是其他程序不需要等待定时器的代码全部执行完毕以后才能执行代码。因为定时器有可能是无限循环执行代码的,如果等待定时器执行完毕那么其他的代码将永远无法运行。所以异步编程就是相对于其他代码是独立完成的。也就是上面所说的ajax是独立于浏览器平台的。

Tip:事件也是异步执行的,事件是发生某件事情后才会执行代码的。
同步:我们之前所写的代码除了定时器和事件大部分都是同步执行的。也就是同一个代码块中都是从上到下执行的。

Ajax的工作原理

Ajax 核心对象XMLHttpRequest
var _hr=new window.XMLHttpRequest();
通过该实例化的对象向服务器
发出请求,等待服务器响应
服务器响应完成后客户端再处理
服务器端响应的数据。
Ajax请求服务器的过程中有5个状态
0:表示请求服务器之前
1:表示打开远程服务器链接对应open方法
2:表示向服务器发送数据对应send方法
3:表示服务器响应过程中并未结束
4:表示服务器响应完成

/**
 * 创建XMLHttpRequest对象
 * @param _method 请求方式: post||get
 * @param _url 远程服务器地址
 * @param _async 是否异步
 * @param _parameter 向服务器发送数据
 * @param _callBack 回调函数
 */
function parameterDeal(_parameter){
  var _sender="";
  if(_parameter instanceof Object){
    for(var k in _parameter){
      _sender+=k+"="+_parameter[k]+"&";
    }
    return _sender.replace(/\&$/g,"");
  }else{
    return _parameter;
  }
}
function createXMLHttpRequest(){
  try{
    return new window.XMLHttpRequest();
  }catch(e){
    try{
      return new ActiveXObject("MSXML2.XMLHTTP.6.0");
    }catch(e){
      try{
        return new ActiveXObject("MSXML2.XMLHTTP.3.0");
      }catch(e){
        try{
          return new ActiveXObject("MSXML2.XMLHTTP");
        }catch(e){
          try{
            return new ActiveXObject("Microsoft.XMLHTTP");
          }catch(e){
            throw new Error("该浏览器版本太低,已经被大部分市场淘汰,请升级!!!");
            return;
          }
        }
      }
    }
  }
}
function ajaxRequest(_method,_url,_async,_parameter,_callBack){
  var _ajax=createXMLHttpRequest();
  if(_ajax){
    _ajax.onreadystatechange=function(){
      if(_ajax.readyState==4 && _ajax.status==200){
        _callBack(_ajax.responseText);
      }
    }
    _ajax.open(_method,_url,_async);
    _ajax.setRequestHeader("content-type","application/x-www-form-urlencoded;charset=utf-8");
    _ajax.send(parameterDeal(_parameter));
  }
}

这是封装好了的原生Ajax,在使用的过程中,只需要新建一个js文件,将这段代码放进去,什么都不要改,在HTML页面引入之后,调用 ajaxRequest()函数,传入你想要的参数,就可以正常使用了。

此方法纯属个人封装,有更精简方法的朋友欢迎与我分享!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery中;function($,undefined) 前面的分号的用处
Dec 17 Javascript
js实现网页图片延时加载 提升网页打开速度
Jan 26 Javascript
基于jQuery下拉选择框插件支持单选多选功能代码
Jun 07 Javascript
浅析vue数据绑定
Jan 17 Javascript
js实现彩色条纹滚动条效果
Mar 15 Javascript
详解angularjs利用ui-route异步加载组件
May 21 Javascript
Vue cli+mui 区域滚动的实例代码
Jan 25 Javascript
Angular2.0实现modal对话框的方法示例
Feb 18 Javascript
基于vue.js实现分页查询功能
Dec 29 Javascript
详解jenkins自动化部署vue
May 14 Javascript
vue 实现用户登录方式的切换功能
Apr 14 Javascript
解决Vue-Router升级导致的Uncaught (in promise)问题
Aug 07 Javascript
ThinkPHP+jquery实现“加载更多”功能代码
Mar 11 #Javascript
Bootstrap的Carousel配合dropload.js实现移动端滑动切换图片
Mar 10 #Javascript
基于Bootstrap框架实现图片切换
Mar 10 #Javascript
angularjs ui-router中路由的二级嵌套
Mar 10 #Javascript
AngularJS ui-router (嵌套路由)实例
Mar 10 #Javascript
微信小程序手势操作之单触摸点与多触摸点
Mar 10 #Javascript
Web纯前端“旭日图”实现元素周期表
Mar 10 #Javascript
You might like
基于MySQL分区性能的详细介绍
2013/05/02 PHP
使用array_map简单搞定PHP删除文件、删除目录
2014/10/29 PHP
PHP递归复制、移动目录的自定义函数分享
2014/11/18 PHP
关于PHP定时发送服务的解决办法
2017/04/23 PHP
PHP基于ICU扩展intl快速实现汉字转拼音及按拼音首字母分组排序的方法
2017/05/03 PHP
用js实现计算加载页面所用的时间
2010/04/02 Javascript
date.parse在IE和FF中的区别
2010/07/29 Javascript
Jquery index()方法 获取相应元素索引值
2012/10/12 Javascript
扩展js对象数组的OrderByAsc和OrderByDesc方法实现思路
2013/05/17 Javascript
谈谈我对JavaScript DOM事件的理解
2015/12/18 Javascript
js实现文字垂直滚动和鼠标悬停效果
2015/12/31 Javascript
Angular和百度地图的结合实例代码
2016/10/19 Javascript
JS跨域请求外部服务器的资源
2017/02/06 Javascript
JQuery中Ajax的操作完整例子
2017/03/07 Javascript
Mongoose经常返回e11000 error的原因分析
2017/03/29 Javascript
nodeJS(express4.x)+vue(vue-cli)构建前后端分离实例(带跨域)
2017/07/05 NodeJs
在Vue methods中调用filters里的过滤器实例
2018/08/30 Javascript
Vuex 快速入门(简单易懂)
2018/09/20 Javascript
JS插入排序简单理解与实现方法分析
2019/11/25 Javascript
JavaScript实现捕获鼠标坐标
2020/04/12 Javascript
jQuery实现鼠标滑动切换图片
2020/05/27 jQuery
vue 需求 data中的数据之间的调用操作
2020/08/05 Javascript
在Python中处理XML的教程
2015/04/29 Python
seek引发的python文件读写的问题及解决
2019/07/26 Python
在pytorch中动态调整优化器的学习率方式
2020/06/24 Python
协程Python 中实现多任务耗资源最小的方式
2020/10/19 Python
python 窃取摄像头照片的实现示例
2021/01/08 Python
解析HTML5中的新功能本地存储localStorage
2016/03/01 HTML / CSS
Stuart Weitzman美国官网:美国奢华鞋履品牌
2016/08/18 全球购物
国际奢侈品品牌童装购物网站:Designer Childrenswear
2019/05/08 全球购物
建筑行业的大学生自我评价
2013/12/08 职场文书
2013的个人自我评价
2013/12/26 职场文书
采购助理岗位职责
2014/02/16 职场文书
《游戏公平》教学反思
2016/02/20 职场文书
Nginx速查手册及常见问题
2022/04/07 Servers
Vue组件化(ref,props, mixin,.插件)详解
2022/05/15 Vue.js