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

发布时间 - 2026-01-11 00:07:08    点击率:

原理及概念

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()函数,传入你想要的参数,就可以正常使用了。

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

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


# js  # Ajax  # 一个AJAX自动完成功能的js封装源码[支持中文]  # 原生Javascript封装的一个AJAX函数分享  # js实现对ajax请求面向对象的封装  # 原生JS封装ajax 传json  # str  # excel文件上传提交表单(推荐)  # JavaScript 封装Ajax传递的数据代码  # 浅析jQuery Ajax通用js封装  # js锁屏解屏通过对$.ajax进行封装实现  # 使用原生js封装的ajax实例(兼容jsonp)  # 纯js封装的ajax功能函数与用法示例  # 原生javascript实现的ajax异步封装功能示例  # 原生js封装的ajax方法示例  # 应用程序  # 都是  # 是一种  # 可使  # 相对于  # 过程中  # 动态网页  # 这是  # 好了  # 有可能  # 不需要  # 才会  # 是指  # 已被  # 中有  # 其他的  # 这段  # 可以通过  # 与我  # 更快 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel中的Facade(门面)到底是什么原理  googleplay官方入口在哪里_Google Play官方商店快速入口指南  如何用搬瓦工VPS快速搭建个人网站?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体  Laravel怎么实现支付功能_Laravel集成支付宝微信支付  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  JavaScript如何实现错误处理_try...catch如何捕获异常?  Android仿QQ列表左滑删除操作  Laravel如何记录自定义日志?(Log频道配置)  如何获取免费开源的自助建站系统源码?  Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】  JavaScript如何实现路由_前端路由原理是什么  zabbix利用python脚本发送报警邮件的方法  Laravel如何实现事件和监听器?(Event & Listener实战)  JavaScript如何实现音频处理_Web Audio API如何工作?  javascript事件捕获机制【深入分析IE和DOM中的事件模型】  利用 Google AI 进行 YouTube 视频 SEO 描述优化  Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】  laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析  简单实现Android验证码  专业商城网站制作公司有哪些,pi商城官网是哪个?  Laravel如何使用Telescope进行调试?(安装和使用教程)  如何用美橙互联一键搭建多站合一网站?  iOS正则表达式验证手机号、邮箱、身份证号等  什么是javascript作用域_全局和局部作用域有什么区别?  Laravel Fortify是什么,和Jetstream有什么关系  百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧  百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  如何打造高效商业网站?建站目的决定转化率  Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解  北京企业网站设计制作公司,北京铁路集团官方网站?  高性价比服务器租赁——企业级配置与24小时运维服务  微信推文制作网站有哪些,怎么做微信推文,急?  Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程  lovemo网页版地址 lovemo官网手机登录  EditPlus中的正则表达式 实战(4)  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤  Laravel怎么清理缓存_Laravel optimize clear命令详解  javascript读取文本节点方法小结  奇安信“盘古石”团队突破 iOS 26.1 提权  Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程  laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法  想要更高端的建设网站,这些原则一定要坚持!  如何在云虚拟主机上快速搭建个人网站?  如何在橙子建站上传落地页?操作指南详解  Laravel怎么做缓存_Laravel Cache系统提升应用速度的策略与技巧  HTML5空格在Angular项目里怎么处理_Angular中空格的渲染问题【详解】