位置: IT常识 - 正文

Axios和Ajax的区别是什么(axios和ajax的关系)

编辑:rootadmin
Axios和Ajax的区别是什么 一、Axios 和 Ajax 的区别

推荐整理分享Axios和Ajax的区别是什么(axios和ajax的关系),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:axios 和ajax,axios和ajax的区别面试题,axios和ajax的区别在哪里,ajax和ashx,web前端三大主流框架,axions和ajax的区别,axions和ajax的区别,web前端三大主流框架,内容如对您有帮助,希望把文章链接给更多的朋友!

1、Axios是一个基于Promise的HTTP库,而Ajax是对原生XHR的封装;

2、Ajax技术实现了局部数据的刷新,而Axios实现了对ajax的封装。

二、Axios 和 Ajax 的区别及优缺点Ajax:1、什么是Ajax

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

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

2、Ajax的原理?

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

3、核心对象?

XMLHttpReques

4、Ajax优缺点?

   优点 

1、无刷新更新数据

2、异步与服务器通信

3、前端和后端负载平衡

4、基于标准被广泛支持

5、界面与应用分离

   缺点:

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

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

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

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

Axios和Ajax的区别是什么(axios和ajax的关系)

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: 'get', url: '/getuser/data', dataType: 'json', data: { firstName: '张', lastName: '三' }, success: function (response) { console.log(response); }, error: function (error) { console.log(error); }});<script type="text/javascript"> function login() { $.ajax({ type: 'post', url: '/email/login', dataType: 'json', data: { 'account': $('#account').val(), 'password': $('#password').val() }, success: function (data) { if (data.code == 1) { alert("登录成功"); window.location.href = "http://localhost:8080/email/success"; } else { alert("密码错误,请重新输入!") window.location.href = "http://localhost:8080/email/error" } } }) }</script><script type="text/javascript"> function addFruit() { let name = $.trim($("#fname").val()); let price = $.trim($("#fprice").val()); let count = $.trim($("#fcount").val()); $.post("http://localhost:8080/fruit/add", {name: name, price: price, count: count}, function (data) { if (data.code == 1) { alert(data.message); window.location.href = "http://localhost:8080/fruit/index"; } if (data.code == 0) { alert(data.message); } }); } function delFruit(id) { if (window.confirm("是否确认删除" + id + "?")) { $.post("http://localhost:8080/fruit/delete?id=" + id, {id: id}, function (data) { if (data.code == 1) { alert(data.message); window.location.href = "http://localhost:8080/fruit/index"; } if (data.code == 0) { alert(data.message); } }); } }</script>8、Ajax请求的五个步骤

1. 创建XMLHttpRequest异步对象

2. 设置回调函数

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

4. 向服务器发送数据

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

Axios:1、Axios是什么

Axios 是一个基于 Promise 的 HTTP 库,可以用在浏览器和 node.js 中。

2、Axios有那些特性?

1、在浏览器中创建 XMLHttpRequests

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

3、支持Promise API

4、支持拦截请求和响应

5、转换请求和响应数据

6、取消请求

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

8、客户端支持防御XSRF

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

params 是用于拼接 url 的,get 请求传参就是拼到 url 中,

而 data 是放在 request body 中的,用于 post 请求

// 第一种写法:将参数直接写在url中axios.get('/query?name=tom').then(function (response) { console.log(response);}).catch(function (error) { console.log(error);});// 第二种写法:将参数直接写在params中axios.get('/query', { params: { name: 'tom' }}).then(function (response) { console.log(response);}).catch(function (error) { console.log(error);});// 第三种写法:将参数直接写在params中axios({ method: 'get', url: '/query', params: { name: 'tom', }}).then(function (response) { console.log(response);}).catch(function (error) { console.log(error);});4、执行post请求,注意执行post请求的入参,不需要写在params字段中,这个地方要注意与get请求的第二种方式进行区别。axios.post('/query', { name: 'tom', icon: 'img_path'}).then(function (response) { console.log(response);}).catch(function (error) { console.log(error);});

 下面这种data方式将参数放在请求体中,后端需要使用@RequestBody +实体类来接收。

axios({ url: '/getUsers', method: 'post', responseType: 'json', // 默认的 data: { age: 18, sex: '男', } }).then(function (response) { console.log(response); console.log(response.data); }).catch(function (error) { console.log(error); });

这种params传参方式其实和get请求类似,把请求参数放到了请求头中,http://127.0.0.1/user?age=18&sex=男 所以这种需要使用@RequestParam来接收参数

axios({ url: '/getUsers', method: 'post', responseType: 'json', // 默认的 params: { age: 18, sex: '男', } }).then(function (response) { console.log(response); console.log(response.data); }).catch(function (error) { console.log(error); });三、Axios和Ajax的区别

axios是通过Promise实现对ajax技术的一种封装,就像jquery对ajax的封装一样,简单来说就是ajax技术实现了局部数据的刷新,axios实现了对ajax的封装,axios有的ajax都有,ajax有的axios不一定有,总结一句话就是axios是ajax,ajax不止axios。

注: 传统Ajax 指的是 XMLHttpRequest(XHR),axios和jQuer ajax都是对Ajax的封装。

本文链接地址:https://www.jiuchutong.com/zhishi/300450.html 转载请保留说明!

上一篇:【自动驾驶】车辆运动学模型(自动驾驶车祸)

下一篇:AI 杀疯了,NovelAI开源教程(杀疯了出自哪里)

  • AirPods3已连接但是没有声音怎么办(airpods3连接显示)

    AirPods3已连接但是没有声音怎么办(airpods3连接显示)

  • 荣耀50支持红外线遥控功能吗(荣耀70支持红外线功能吗)

    荣耀50支持红外线遥控功能吗(荣耀70支持红外线功能吗)

  • vivo手机如何查看本机号码(vivo手机如何查看帧率)

    vivo手机如何查看本机号码(vivo手机如何查看帧率)

  • 华为mate30pro支持4g版吗(华为mate30pro支持5g网络吗)

    华为mate30pro支持4g版吗(华为mate30pro支持5g网络吗)

  • 华为查找手机对方会有提示吗(华为查找手机对方手机有提示)

    华为查找手机对方会有提示吗(华为查找手机对方手机有提示)

  • 支付宝怎么拍电子版照片(支付宝怎么拍电子照)

    支付宝怎么拍电子版照片(支付宝怎么拍电子照)

  • 笔记本电脑的无线网络开关在哪里 (笔记本电脑的无线开关在哪里打开)

    笔记本电脑的无线网络开关在哪里 (笔记本电脑的无线开关在哪里打开)

  • qq能关闭空间入口吗(qq能关闭空间入访吗)

    qq能关闭空间入口吗(qq能关闭空间入访吗)

  • 华为wifi已连接但有感叹号(华为wifi已连接不可上网是什么原因)

    华为wifi已连接但有感叹号(华为wifi已连接不可上网是什么原因)

  • vivos5充电速度(vivos5充电多少分钟充满电)

    vivos5充电速度(vivos5充电多少分钟充满电)

  • 苹果se和11的区别(苹果se和11哪个好)

    苹果se和11的区别(苹果se和11哪个好)

  • 为什么微信拉了黑名单,还是能收到信息(为什么微信拉了群没有提示)

    为什么微信拉了黑名单,还是能收到信息(为什么微信拉了群没有提示)

  • 淘宝记录能彻底删除吗(淘宝历史记录删除)

    淘宝记录能彻底删除吗(淘宝历史记录删除)

  • 两个微信可以合并成一个吗(两个微信可以合并在一起吗)

    两个微信可以合并成一个吗(两个微信可以合并在一起吗)

  • 华为crr ul00又叫什么(华为crr-ul20是什么型号)

    华为crr ul00又叫什么(华为crr-ul20是什么型号)

  • 华为nova5ipro支持nfc吗(华为nova5ipro支持快充吗)

    华为nova5ipro支持nfc吗(华为nova5ipro支持快充吗)

  • vivox20什么时间出的(vivox20多久发布的)

    vivox20什么时间出的(vivox20多久发布的)

  • 华为震动大小在哪设置(华为手机震动大小在哪设置)

    华为震动大小在哪设置(华为手机震动大小在哪设置)

  • 苹果11对比苹果x(苹果11对比苹果xs参数)

    苹果11对比苹果x(苹果11对比苹果xs参数)

  • 链家app如何预约看房(链家网上签约怎么签约的)

    链家app如何预约看房(链家网上签约怎么签约的)

  • 华为bkkal10什么型号(华为bkkal10什么型号多少钱)

    华为bkkal10什么型号(华为bkkal10什么型号多少钱)

  • 来分期密码忘了怎么办(来分期忘记密码电话也换了怎么办)

    来分期密码忘了怎么办(来分期忘记密码电话也换了怎么办)

  • Win10 Build 19043.1147 (21H1)预览通道更新补丁KB5004296(附完整更新日志)

    Win10 Build 19043.1147 (21H1)预览通道更新补丁KB5004296(附完整更新日志)

  • 发现新大陆——原来软件开发根本不需要会编码(看我10分钟应用上线)(发现新大陆的是麦哲伦还是哥伦布)

    发现新大陆——原来软件开发根本不需要会编码(看我10分钟应用上线)(发现新大陆的是麦哲伦还是哥伦布)

  • 独资企业赚的钱全是老板的吗
  • 公司清理固定资产汽车怎么开票
  • 发票备注没写
  • 拍卖公司都要交前期费用吗?
  • 土地转让契税税率2020税率表
  • 现金短缺溢余求借多少短期借款?
  • 外购的材料用于在建工程进项税额
  • 企业报税盘入账应该记入哪个科目?
  • 企业收到财政补助项目款
  • 企业无法收回的账款
  • 个税手续费返还会计分录
  • 跨年的发票可以冲红重开吗
  • 年底自查
  • 应向客户收取的出租包装物租金
  • 消费型增值税的特点的是( )
  • 个人贷款走公司账户流程
  • 实收资本入账价值怎么算
  • 上个月印花税少计提了怎么办
  • 激活windows11怎么激活
  • 冲回坏账
  • 代扣的工会会费怎么做账
  • 以房产投资联营,收取固定收入,不承担联营风险的房产
  • 用人单位如何缴纳医疗保险
  • 企业可以超范围经营吗
  • 回迁房办产权证的时候需要交多少钱
  • 按工资的14%计提职工福利费
  • 约克大教堂是基督教吗
  • 企业出租房屋怎么做账
  • 小规模纳税人的企业所得税税率
  • 大二期末要考试吗
  • echarts api文档
  • 减免税款月末怎么结转
  • mysql中regexp_replace函数的使用
  • 回购股票 会计处理
  • 限售股 缴税
  • 代销费是谁给谁
  • 增值税一般纳税人登记管理办法
  • 记账凭证装订好了如何在拆开
  • 建筑公司内账收什么费用
  • PostgreSQL ERROR: invalid escape string 解决办法
  • 小规模纳税人开专票税率是1%还是3%
  • 所得税核定征收的政策
  • 收购企业如何做账
  • 企业股权转让收入会计处理
  • 跨年的个人所得税可以更正吗
  • 以旧换新会计科目
  • 银行现金支票作废处理步骤
  • 资本溢价产生的主要原因
  • 税控盘被锁死
  • 为什么看科目四看不进去呀
  • 去年的进项发票今年怎么入账
  • 原始凭证留存几年
  • 虚拟系统win10
  • windows蓝屏代码大全及解决方案
  • windowxp一直在windowxp界面
  • xp系统怎么禁止软件联网
  • win10麦克风加强没有了
  • mac系统怎么共享文件夹
  • linux bash sh
  • 怎么改电脑windows7
  • Windows XP Professional VLK SP2 简体中文版
  • macbook怎么新建txt文件
  • ssh用法及命令
  • jquery22插件网
  • python函数enumerate
  • perl脚本输出变量
  • 粉碎文件的快捷键
  • appendChild() 或 insertBefore()使用与区别介绍
  • 在全盘搜索以win
  • unity游戏开发简历
  • javascript教程
  • 不用javascript可以吗
  • typescript的缺点
  • 国家税务局级别排名
  • 发票查验怎么弄
  • 消费税要把增值税算进去吗
  • 无锡电子税务局怎么修改办税人员信息
  • 四川医保增员网上怎么操作流程图
  • 河南机构改革人员名单
  • 计提印花税入什么科目核算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设