位置: 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开源教程(杀疯了出自哪里)

  • 耳机左耳比右耳声音大(耳机左耳比右耳耗电快)

    耳机左耳比右耳声音大(耳机左耳比右耳耗电快)

  • oppo手机的备忘录在哪里打开(oppo手机的备忘录叫什么名字)

    oppo手机的备忘录在哪里打开(oppo手机的备忘录叫什么名字)

  • 移动权益版手机是什么意思(移动权益版手机可以卖吗)

    移动权益版手机是什么意思(移动权益版手机可以卖吗)

  • 华为聊天记录怎么能恢复(华为聊天记录怎么彻底删除)

    华为聊天记录怎么能恢复(华为聊天记录怎么彻底删除)

  • 拼多多溢价是什么意思(拼多多溢价率)

    拼多多溢价是什么意思(拼多多溢价率)

  • 帧速率是不是越高越好(帧速率是不是越低越好)

    帧速率是不是越高越好(帧速率是不是越低越好)

  • 探探单方面解除对方还有我吗(探探单方面解除对方还有聊天记录吗)

    探探单方面解除对方还有我吗(探探单方面解除对方还有聊天记录吗)

  • 钉钉直播上课能看到学生吗(钉钉直播上课能踢出某些人嘛)

    钉钉直播上课能看到学生吗(钉钉直播上课能踢出某些人嘛)

  • 知道群号怎么加入qq群(知道群号怎么加入群聊)

    知道群号怎么加入qq群(知道群号怎么加入群聊)

  • 天猫超市卡为什么有钱(天猫超市卡为什么会过期)

    天猫超市卡为什么有钱(天猫超市卡为什么会过期)

  • 美版kindle pw4和国行差别(kindle pw4美版和国行区别)

    美版kindle pw4和国行差别(kindle pw4美版和国行区别)

  • dc头2.1和2.5如何区分(dc2.1和2.5区别)

    dc头2.1和2.5如何区分(dc2.1和2.5区别)

  • 企业路由器和家用路由器的区别(企业路由器和家用路由器哪个穿墙好)

    企业路由器和家用路由器的区别(企业路由器和家用路由器哪个穿墙好)

  • 火山小视频亚健康一般封几天(…火山小视频 原版)

    火山小视频亚健康一般封几天(…火山小视频 原版)

  • 电话怎么输入字母(电话怎么打字母)

    电话怎么输入字母(电话怎么打字母)

  • 荣耀v30发布时间(荣耀v30发布时间及价格)

    荣耀v30发布时间(荣耀v30发布时间及价格)

  • 在word中撤销功能的快捷键是(word中的撤销操作)

    在word中撤销功能的快捷键是(word中的撤销操作)

  • 手机怎么改路由器密码(手机怎么改路由器信道)

    手机怎么改路由器密码(手机怎么改路由器信道)

  • 华为mate30微信视频美颜怎么设置

    华为mate30微信视频美颜怎么设置

  • 华为手机车载模式在哪(华为手机车载模式自动开热点)

    华为手机车载模式在哪(华为手机车载模式自动开热点)

  • iphonexr支持多少w快充(iPhonexr支持多少w充电)

    iphonexr支持多少w快充(iPhonexr支持多少w充电)

  • 苹果电池多少需要更换(苹果电池达到多少需要换)

    苹果电池多少需要更换(苹果电池达到多少需要换)

  • iphone xs max长宽(iphone xs max尺寸长宽厘米)

    iphone xs max长宽(iphone xs max尺寸长宽厘米)

  • 电脑屏幕保护不能设置时间怎么办?(电脑屏幕保护不能设置)

    电脑屏幕保护不能设置时间怎么办?(电脑屏幕保护不能设置)

  • cdplay命令  CD播放工具(cd播放模式)

    cdplay命令 CD播放工具(cd播放模式)

  • Java 中九种 Map 的遍历方式,你一般用的是哪种呢?(java中map.entry)

    Java 中九种 Map 的遍历方式,你一般用的是哪种呢?(java中map.entry)

  • 安装服务费增值税专票税率多少
  • 增值税和附加税如何计算
  • 现金及现金等价物期末余额
  • 小规模未达起征点的增值税怎么做账
  • 报销宽带费属于什么科目
  • 无票收入应该怎么做
  • 五金配件领用管理流程
  • 小规模商贸公司没有进项可以开发票吗?
  • 扣缴义务人怎么删除
  • 债务重组的会计准则
  • 员工出差火车票可以抵扣进项吗
  • 调拨入库的固定资产是否缴税?
  • 工程款为什么要扣税
  • 进项税额转出报税填哪个表
  • 发票打印机的字偏上
  • 发票认证勾选是一回事吗
  • 并购重组协议样本
  • 定期定额征收适用范围
  • 税款已入库,申报错误更正可以吗
  • 企业所得税三项费用扣除
  • 销售产品的成本属于什么科目
  • 一次性工伤补偿金公司不给怎么办
  • 享受小型微利企业税收优惠的条件
  • 社保怎么计提
  • 方正书版10.0教程
  • 房地产业务招待费
  • 提取的坏账准备怎么算
  • 年度所得税报表在哪里查到
  • layui 日期控件赋值
  • bind函数错误
  • php 数学函数
  • web前端开发规范有哪些
  • 个体工商户可以给自己交社保吗
  • 律师事务所执业证
  • 递延所得税资产借贷方向
  • ca证书在线延期不成功
  • c语言中局部变量和全局变量同名
  • mysql常用命令汇总
  • 印花税计提怎么做分录
  • 企业电子发票重开流程
  • 企业工会经费计提比例
  • 本期数值与去年同期数值之差称为什么
  • mysql常见故障
  • 物业广告怎么收费
  • 应收账款属于会计分录
  • 上年期末留底税额怎么算
  • 季节性生产企业有哪些
  • 还借款收据怎么写
  • 购入财务软件如何入账
  • 房屋租赁合同印花税谁交
  • 母子公司合并报表实操
  • 企业所得税国税地税怎么分
  • 负库存金额
  • 开出去的发票
  • 财务人员如何审合同课件
  • 营业成本包括哪些会计科目
  • 备查账一般采用什么账簿
  • sqlserver锁机制
  • sql语句优化的13种方法
  • mysql 绿色版
  • mac上的home键在哪
  • mac下mysql密码忘记了怎么办
  • fedora安装xorg
  • win2003进入安全模式
  • win2003无法启动
  • slmgr.vbs /dli
  • 修改linuxip
  • mac系统文件名
  • ubuntu20关机卡在logo
  • 从此学会隐藏悲伤全文
  • centos怎么安装
  • win8.1系统要求配置
  • Win10 Mobile RedStone预览版14267更新内容汇总(持续更新)
  • fetch怎么用
  • android中的短信联系人管理,浏览器属于
  • js引用传递
  • 电子税务局打印发票提示本机未检测到
  • 广州电子税局
  • 山东中信银行电话
  • 增值税率下降
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设