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


相关推荐: Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】  如何安全更换建站之星模板并保留数据?  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  米侠浏览器网页图片不显示怎么办 米侠图片加载修复  EditPlus中的正则表达式实战(5)  Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南  Laravel Asset编译怎么配置_Laravel Vite前端构建工具使用  laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法  如何自定义建站之星模板颜色并下载新样式?  Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧  Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  Laravel如何使用Laravel Vite编译前端_Laravel10以上版本前端静态资源管理【教程】  Android自定义listview布局实现上拉加载下拉刷新功能  为什么要用作用域操作符_php中访问类常量与静态属性的优势【解答】  Laravel N+1查询问题如何解决_Eloquent预加载(Eager Loading)优化数据库查询  Python图片处理进阶教程_Pillow滤镜与图像增强  html5的keygen标签为什么废弃_替代方案说明【解答】  如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】  如何在浏览器中启用Flash_2025年继续使用Flash Player的方法【过时】  Win11怎么开启自动HDR画质_Windows11显示设置HDR选项  Laravel如何实现事件和监听器?(Event & Listener实战)  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  Swift开发中switch语句值绑定模式  如何用狗爹虚拟主机快速搭建网站?  JavaScript常见的五种数组去重的方式  Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】  Laravel如何处理异常和错误?(Handler示例)  做企业网站制作流程,企业网站制作基本流程有哪些?  Windows Hello人脸识别突然无法使用  HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】  ,在苏州找工作,上哪个网站比较好?  php 三元运算符实例详细介绍  Laravel如何使用Sanctum进行API认证?(SPA实战)  Laravel如何实现密码重置功能_Laravel密码找回与重置流程  非常酷的网站设计制作软件,酷培ai教育官方网站?  Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试  高端建站如何打造兼具美学与转化的品牌官网?  Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】  Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】  消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】  成都网站制作公司哪家好,四川省职工服务网是做什么用?  Laravel如何优化应用性能?(缓存和优化命令)  Laravel如何从数据库删除数据_Laravel destroy和delete方法区别