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 表格合并的问题分享
Sep 17 Javascript
IE6-IE9不支持table.innerHTML的解决方法分享
Sep 14 Javascript
浅析Node.js 中 Stream API 的使用
Oct 23 Javascript
深入解析Backbone.js框架的依赖库Underscore.js的作用
May 07 Javascript
JavaScript实现横线提示输入验证码随输入验证码输入消失的方法
Sep 24 Javascript
vue实现简单实时汇率计算功能
Jan 15 Javascript
js 获取元素的具体样式信息getcss(实例讲解)
Jul 05 Javascript
微信小程序实现简单input正则表达式验证功能示例
Nov 30 Javascript
解决angularjs WdatePicker ng-model的问题
Sep 13 Javascript
vscode下vue项目中eslint的使用方法
Jan 13 Javascript
使用layer弹窗提交表单时判断表单是否输入为空的例子
Sep 26 Javascript
Html5生成验证码的示例代码
May 10 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
php批量删除数据库下指定前缀的表以prefix_为例
2014/08/24 PHP
PHP编程快速实现数组去重的方法详解
2017/07/22 PHP
Jquery 最近浏览过的商品的功能实现代码
2010/05/14 Javascript
jQuery获得内容和属性方法及示例
2013/12/02 Javascript
Javascript递归打印Document层次关系实例分析
2015/05/15 Javascript
JQuery分屏指示器图片轮换效果实例
2015/05/21 Javascript
超精准的javascript验证身份证号的具体实现方法
2015/11/18 Javascript
jQuery基于排序功能实现上移、下移的方法
2016/11/26 Javascript
express+mockjs实现模拟后台数据发送功能
2018/01/07 Javascript
基于vue cli重构多页面脚手架过程详解
2018/01/23 Javascript
详解vue中点击空白处隐藏div的实现(用指令实现)
2018/04/19 Javascript
深度了解vue.js中hooks的相关知识
2019/06/14 Javascript
javascript事件监听与事件委托实例详解
2019/08/16 Javascript
Vue3.0数据响应式原理详解
2019/10/09 Javascript
Vue实现导航栏菜单
2020/08/19 Javascript
Python内置函数Type()函数一个有趣的用法
2015/02/18 Python
Python线程中对join方法的运用的教程
2015/04/09 Python
python Django框架实现自定义表单提交
2016/03/25 Python
尝试用最短的Python代码来实现服务器和代理服务器
2016/06/23 Python
Python并发之多进程的方法实例代码
2018/08/15 Python
解决python opencv无法显示图片的问题
2018/10/28 Python
神经网络相关之基础概念的讲解
2018/12/29 Python
Python循环结构的应用场景详解
2019/07/11 Python
react+django清除浏览器缓存的几种方法小结
2019/07/17 Python
详解Python list和numpy array的存储和读取方法
2019/11/06 Python
浅谈Python type的使用
2019/11/19 Python
Python使用ElementTree美化XML格式的操作
2020/03/06 Python
python 两个一样的字符串用==结果为false问题的解决
2020/03/12 Python
基于python实现简单网页服务器代码实例
2020/09/14 Python
纯CSS3实现滚动的齿轮动画效果
2014/06/05 HTML / CSS
CSS3过渡transition效果实例介绍
2016/05/03 HTML / CSS
美国Curacao百货连锁店网站:iCuracao.com
2019/07/20 全球购物
巴西化妆品商店:Lojas Rede
2019/07/26 全球购物
初中地理教学反思
2014/01/11 职场文书
食品仓管员岗位职责
2015/04/01 职场文书
光荣之路观后感
2015/06/12 职场文书