ajax和axios区别及优缺点

ajax和axios区别及优缺点ajax 和 axios 介绍 原理 区别及优缺点

ajax和axios区别及优缺点

  • axios是一个基于promise 的 http库,主要实现 ajax异步通信功能,用于向后端发起请求,还有在请求中做更多是可控功能;
  • ajax是对原生XHR的封装;
  • axios实现对 ajax封装,ajax实现局部数据的刷新;

一、ajax

1、什么是ajax

Ajax是对原生XHR的封装,为了达到我们跨越的目的,增添了对JsonP的支持。

异步的 javascript和 xml,ajax不是一门新技术,而是多种技术的组合,用于快速的创建动态页面,能够实现无刷新更新数据从而提高用户体验。
  属性:url、method、dataType、beforeSend、success、error…

2、ajax的原理?

由客户端请求ajax引擎,再由ajax引擎请求服务器,服务器作出一系列响应之后返回给ajax引擎,由ajax引擎决定将这个结果写入到客户端的什么位置。实现页面无刷新更新数据。

3、核心对象?

XMLHttpRequest

4、ajax优缺点?

优点:

1、无刷新更新数据

2、异步与服务器通信

3、前端和后端负载平衡

4、基于标准被广泛支持

5、界面与应用分离

缺点:

1、ajax不能使用Back和history功能,即对浏览器机制的破坏

2、安全问题 ajax暴露了与服务器交互的细节

3、对搜索引擎的支持比较弱

4、破坏程序的异常处理机制

5、违背URL和资源定位的初衷

6、ajax不能很好的支持移动设备

7、太多客户端代码造成开发上的成本

5、Ajax适用场景
  1、表单驱动的交互
  2、深层次的树的导航
  3、快速的用户与用户间的交流响应
  4、类似投票、yes/no等无关痛痒的场景
  5、对数据进行过滤和操纵相关数据的场景
  6、普通的文本输入提示和自动完成的场景
6、Ajax不适用场景
  1、部分简单的表单
  2、搜索
  3、基本的导航
  4、替换大量的文本
  5、对呈现的操纵
























7、代码

$.ajax({ 
    type: 'POST', url: url, data: data, dataType: dataType, success: function () { 
   }, error: function () { 
   } }); 

8、ajax请求的五个步骤

1、创建XMLHttpRequest异步对象

2、设置回调函数

3、使用open方法与服务器建立连接

4、向服务器发送数据

5、在回调函数中针对不同的响应状态进行处理

二、axios

1、axios是什么

1、在浏览器中创建 XMLHttpRequests

2、在node.js则创建http请求

3、支持Promise API

4、支持拦截请求和响应

5、转换请求和响应数据

6、取消请求

7、自动转换成JSON数据格式

8、客户端支持防御XSRF

9、提供了一些并发请求的接口(重要)

3、执行get请求,有两种方式

// 第一种方式 将参数直接写在url中 axios.get('/getMainInfo?id=123') .then((res) => { 
    console.log(res) }) .catch((err) => { 
    console.log(err) }) // 第二种方式 将参数直接写在params中 axios.get('/getMainInfo', { 
    params: { 
    id: 123 } }) .then((res) => { 
    console.log(res) }) .catch((err) => { 
    console.log(err) }) 

4、执行post请求,注意执行post请求的入参,不需要写在params字段中,这个地方要注意与get请求的第二种方式进行区别。

axios.post('/getMainInfo', { 
    id: 123 }) .then((res) => { 
    console.log(res) }) .catch((err) => { 
    console.log(err) }) 

axios和ajax的区别:

axios是通过Promise实现对ajax技术的一种封装,就像jquery对ajax的封装一样,axios回来的数据是promise,ajax回来的数据是回调,axios比ajax更好用更安全。

简单来说就是ajax技术实现了局部数据的刷新,axios实现了对ajax的封装;axios有的ajax都有,ajax有的axios不一定有。

总结一句话就是axios是ajax,ajax不止axios。

更多资源

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/204299.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月19日 下午8:35
下一篇 2026年3月19日 下午8:36


相关推荐

  • BeanUtils.populate方法的作用

    BeanUtils.populate方法的作用一般来说,这个方法是在org.apache.commons.beanutils.BeanUtils包中的方法。该方法的函数原型为:BeanUtils.populate(Objectbean,Mapproperties)。这个方法会遍历map<key,value>中的key,如果bean中有这个属性,就把这个key对应的value值赋给bean的属性。具体使用方法,见…

    2022年7月26日
    6
  • 设置VirtualBox共享文件夹的方法

    设置VirtualBox共享文件夹的方法文章难度 入门环境 软件环境 VirtualBox 5 2 34 主机操作系统 Windows7 专业版虚拟机操作系统 Ubuntu16 04Desktopamd 硬件环境 CPU Inteli5 内存 8G 当使用 VirtualBox 的 Ubuntu 虚拟机时 我们有时希望将 Windows 的目录挂载到虚拟机 Ubuntu 里 实现两个系统之间的文件交换 可能有些同学会问

    2026年3月20日
    2
  • ubuntu16.04安装搜狗输入法_ubuntu18.04安装搜狗输入法

    ubuntu16.04安装搜狗输入法_ubuntu18.04安装搜狗输入法首先安装fcitx一、检测是否安装fcitx首先检测是否有fcitx,因为搜狗拼音依赖fcitx>fcitx提示:程序“fcitx”尚未安装。您可以使用以下命令安装:>sudoapt-getinstallfcitx-bin二、安装fcitxsudoapt-getinstallfcitx-bin相关的依赖库和框架都会自动安装上。sudoapt-getinstall…

    2022年10月18日
    5
  • 查询锁表语句Oracle_会sql语句引起锁定

    查询锁表语句Oracle_会sql语句引起锁定–oracle查询锁表解锁语句–首先要用dba权限的用户登录,建议用system,然后直接看sql吧1.如下语句查询锁定的表.SELECTL.SESSION_IDSID,S.SERIAL#,L.LOCKED_MODE,L.ORACLE_USERNAME,L.OS_USER_NAME,S.MACHINE,…

    2022年8月23日
    6
  • VS2022安装教程(超详细)

    VS2022安装教程(超详细)一 学习 C C 语言用什么环境 DevC 很久不在更新 对于 C 语言的标准支持不够好 vc6 0 太古老 98 年的软件了二 那小编推荐什么大家用什么软件 VS2013 及以上版本都行 今天跟大家唠如何安装 VS2022 听说 VS 官网更新了 小伙伴们找不到 VS2019 了 三 VS2019 下载官网 VS2022 官网 https visualstudio microsoft com zh hans rr https www microsoft com zh cn 3 1 点击 VS

    2026年3月16日
    2
  • 群晖 winscp php,群晖DSM开启ROOT权限及WinSCP使用ROOT登录

    群晖 winscp php,群晖DSM开启ROOT权限及WinSCP使用ROOT登录本文以群晖DSM6.1.7(以下简称DSM)为例:一、准备工具1、putty2、WinSCP下载地址:http://pan.myxzy.com/download.php?id=81二、DSM开启SSHDSM的“控制面板”—>“终端机和SNMP”,勾上“启动Telnet功能”和“启动SSH功能”的勾,然后点击“应用”三、开启ROOT账号和修改密码1、使用putty连接DSM主机名称填…

    2022年6月6日
    1.4K

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号