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 相关文章推荐
JS 动态加载脚本的4种方法
May 05 Javascript
修改file按钮的默认样式实现代码
Apr 23 Javascript
jquery中的事件处理详细介绍
Jun 24 Javascript
jquery实现邮箱自动补全功能示例分享
Feb 17 Javascript
js控制文本框输入的字符类型方法汇总
Jun 19 Javascript
javascript+HTML5的canvas实现七夕情人节3D玫瑰花效果代码
Aug 04 Javascript
浅析Bootstrap表格的使用
Jun 23 Javascript
Bootstrap选项卡与Masonry插件的完美结合
Jul 06 Javascript
vue+iview 实现可编辑表格的示例代码
Oct 31 Javascript
vue elementUI table 自定义表头和行合并的实例代码
May 22 Javascript
Vue中axios拦截器如何单独配置token
Dec 27 Javascript
使用Vue.js和MJML创建响应式电子邮件
Mar 23 Vue.js
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
PHP 数组实例说明
2008/08/18 PHP
php 运行效率总结(提示程序速度)
2009/11/26 PHP
PHP 读取文件内容代码(txt,js等)
2009/12/06 PHP
让PHP开发者事半功倍的十大技巧小结
2010/04/20 PHP
Laravel框架学习笔记(二)项目实战之模型(Models)
2014/10/15 PHP
php强制用户转向www域名的方法
2015/06/19 PHP
php根据日期显示所在星座的方法
2015/07/13 PHP
Codeigniter控制器controller继承问题实例分析
2016/01/19 PHP
Yii2前后台分离及migrate使用(七)
2016/05/04 PHP
php实现购物车功能(以大苹果购物网为例)
2017/03/09 PHP
PHP实现的一致性Hash算法详解【分布式算法】
2018/03/31 PHP
phpMyAdmin通过密码漏洞留后门文件
2018/11/20 PHP
JQuery autocomplete 使用手册
2010/04/01 Javascript
加载jQuery后$冲突的解决办法
2010/07/09 Javascript
JavaScript实现找出数组中最长的连续数字序列
2014/09/03 Javascript
BootStrap轮播HTML代码(推荐)
2016/12/10 Javascript
原生js实现返回顶部缓冲效果
2017/01/18 Javascript
全面解析Node.js 8 重要功能和修复
2017/06/02 Javascript
对于js垃圾回收机制的理解
2017/09/14 Javascript
详解vue-router 命名路由和命名视图
2018/06/01 Javascript
详解Vue内部怎样处理props选项的多种写法
2018/11/06 Javascript
vue-router beforeEach跳转路由验证用户登录状态
2018/12/26 Javascript
vue-for循环嵌套操作示例
2019/01/28 Javascript
[01:48]完美圣典齐天大圣至宝宣传片
2016/12/17 DOTA
python3+PyQt5实现自定义分数滑块部件
2018/04/24 Python
python 利用浏览器 Cookie 模拟登录的用户访问知乎的方法
2019/07/11 Python
Tensorflow 定义变量,函数,数值计算等名字的更新方式
2020/02/10 Python
如何利用python检测图片是否包含二维码
2020/10/15 Python
python 利用Pyinstaller打包Web项目
2020/10/23 Python
应届生保险求职信
2013/11/11 职场文书
教师应聘个人求职信
2013/12/10 职场文书
市级绿色学校申报材料
2014/08/25 职场文书
倡议书格式
2014/08/30 职场文书
高中生思想道德自我评价
2015/03/09 职场文书
死者家属慰问信
2015/03/24 职场文书
2015年社区纪检工作总结
2015/04/21 职场文书