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

  • icloud自动续费怎么取消订阅(icloud 自动续费)

    icloud自动续费怎么取消订阅(icloud 自动续费)

  • oppofindx2pro是双模5G的吗(oppofindx2pro是双卡双待吗)

    oppofindx2pro是双模5G的吗(oppofindx2pro是双卡双待吗)

  • 抖音直播不清晰如何调(抖音直播数据)

    抖音直播不清晰如何调(抖音直播数据)

  • 三星note9是不是双4g

    三星note9是不是双4g

  • 腾讯会议如何发弹幕(腾讯会议如何发图片?)

    腾讯会议如何发弹幕(腾讯会议如何发图片?)

  • cdytn00是华为什么型号(cdyanoo是华为什么型号)

    cdytn00是华为什么型号(cdyanoo是华为什么型号)

  • 移动停机了充话费后多久恢复(移动停机了充话费有用吗)

    移动停机了充话费后多久恢复(移动停机了充话费有用吗)

  • 4g高清通话功能是什么意思

    4g高清通话功能是什么意思

  • 微信表情吃瓜是什么意思(微信表情包吃瓜表达什么意思)

    微信表情吃瓜是什么意思(微信表情包吃瓜表达什么意思)

  • word怎么用斜线(word怎么用斜线划掉字)

    word怎么用斜线(word怎么用斜线划掉字)

  • word水平居中怎么设置(word水平居中怎么改动字体)

    word水平居中怎么设置(word水平居中怎么改动字体)

  • ipada2152是什么型号(ipada2152是国行吗)

    ipada2152是什么型号(ipada2152是国行吗)

  • 华为手机可以隐藏软件吗(华为手机可以隐藏应用软件)

    华为手机可以隐藏软件吗(华为手机可以隐藏应用软件)

  • 苹果手机怎么调充电模式(苹果手机怎么调音量)

    苹果手机怎么调充电模式(苹果手机怎么调音量)

  • 如何让歌词在手机桌面(如何让歌词在手机上显示)

    如何让歌词在手机桌面(如何让歌词在手机上显示)

  • 如何解除青少年模式(如何解除青少年游戏限制)

    如何解除青少年模式(如何解除青少年游戏限制)

  • 抖音屏幕上的字怎么流动的(抖音屏幕上的字怎么跟着音乐走)

    抖音屏幕上的字怎么流动的(抖音屏幕上的字怎么跟着音乐走)

  • 微信记录删除了怎么恢复(微信记录删除了警方能调出来吗)

    微信记录删除了怎么恢复(微信记录删除了警方能调出来吗)

  • 手机qq心悦会员在哪看(手机qq心悦会员图标没了)

    手机qq心悦会员在哪看(手机qq心悦会员图标没了)

  • 苹果手机开不开机了是怎么回事(苹果手机开不开机了怎么办?)

    苹果手机开不开机了是怎么回事(苹果手机开不开机了怎么办?)

  • 电脑CPU风扇不稳定怎么解决?(电脑cpu风扇不动怎么办)

    电脑CPU风扇不稳定怎么解决?(电脑cpu风扇不动怎么办)

  • Stable Diffusion 准确绘制人物动作及手脚细节(需ControlNet扩展)

    Stable Diffusion 准确绘制人物动作及手脚细节(需ControlNet扩展)

  • Win11 KB5023778更新推送 22621.1485预览版更新内容汇总(win11更新71)

    Win11 KB5023778更新推送 22621.1485预览版更新内容汇总(win11更新71)

  • Vue基础开发入门之简单语法知识梳理(思维导图详解)(vue开发需要掌握哪些知识)

    Vue基础开发入门之简单语法知识梳理(思维导图详解)(vue开发需要掌握哪些知识)

  • 预收款增值税纳税义务发生时间与确认收入时间
  • 什么是一般公共财政预算收入
  • 买烟草可以开发票吗
  • 公允价值变动损益增加记哪方
  • 股份公司要实缴
  • 用于职工住宿的会计科目
  • 企业所得税的优点有哪些
  • 协会会费支出计什么科目
  • 建筑公司对外如何开票
  • 民事诉讼的适用范围和基本制度
  • 案例分析互联网巨头的战略计划
  • 不征税发票报税怎么报
  • 个税提前预缴怎么入账?
  • 发票后附的销售清单怎么黏
  • 为什么负债不等于亏损
  • 销售返点的账务处理及税务处理
  • 进口应税消费品所支付的金额不包括
  • 受伤员工补贴
  • 收到快递关税做什么科目
  • 在国外餐厅吃饭服务费和税费
  • 管理费是否需合计
  • 应收及预付款项包括( )
  • 投资预算的编制方法
  • 广告业文化事业建设费2023标准
  • php实现保存网站内容
  • php composer自动加载
  • 苹果保护你的隐私
  • 行政单位预付款已收到货物无发票
  • 资金占用利息会计处理
  • jinjia.exe进程
  • 只有使用权的房子能继承吗
  • PHP:gmstrftime()的用法_Date Time函数
  • 企业发生的直接用于产品生产,专门设有成本项目的费用
  • laypage分页
  • 商品流通企业一般采用
  • 增值税核算账务处理办法
  • php跳转微信支付
  • 基础kl
  • 自动驾驶科普
  • php用mysql连接数据库并查询
  • 收到员工的社保费用记什么科目
  • 银行代发工资当天改工资卡来得及吗
  • 定额发票在哪查真伪
  • 分公司和总公司的账务处理
  • 2022年最新办公用房标准
  • sql server使用sql语句
  • 支付劳务费会计科目怎么写
  • 无法支付的应付账款转作营业外收入
  • 企业的业务招待费属于什么费用
  • SQL Server 2005的cmd_shell组件的开启方法
  • db2数据库安装服务器的环境
  • 通货膨胀溢价的英文
  • 稳岗返还的概念
  • 企业汇算清缴必须要做审计吗
  • 营业外收入是损益类账户吗
  • 退回货款给客户怎么做会计分录
  • 销货方开红字发票
  • 可转换债券转换时的会计处理
  • sql server 复制表中行数据
  • mysql5624安装教程
  • win10+Ubuntu16.04 LTS双系统完美教程(图文教程)
  • win7旗舰版怎么把桌面移动到其他盘
  • win8旗舰版官方下载
  • win10系统预览版
  • win7同步中心怎么关掉
  • StatusClient.exe - StatusClient是什么进程 有什么作用
  • linux操作系统入门教程
  • linux中安装软件可使用哪些方式
  • win10右键图片
  • 右键菜单中添加文字
  • 星球大战与高达的关系
  • js获取上传文件的文件名
  • Express + Session 实现登录验证功能
  • Android优化蓝牙
  • jquery当前时间
  • Python判断字符串结尾并输出yes或no
  • ajax获取数据两种类型
  • 个人所得税减免申报操作流程
  • 城市维护建设税怎么算
  • 新余契税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设