普元EOS-微前端调用base基座的ajax

2024-08-24 12:36

本文主要是介绍普元EOS-微前端调用base基座的ajax,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 前言

微前端调用EOS应用的服务或API,需要引入base基座,然后使用base基座中的ajax方法。

本文将介绍微前端的高开和低开使用base基座的Ajax的方法。

强烈建议不要自己引入axios或其他ajax库,因为EOS的服务接口都要求身份验证和授权,ajax请求时必须携带必要的用户信息,自己封装这些很麻烦,直接使用基座的AjaxUtil对象将非常简单

2 高开页面引入基座的Ajax

在高开页面引入Ajax代码和简单,只要页面中添加下面的代码。

import { AjaxUtil } from 'base/lib'

然后可以使用AjaxUtil工具进行get或post的方式请求。

在AjaxUtil可以获得ajax对象,调用方法如下:

const ajax1 = AjaxUtil.headers(AjaxUtil.buildHeaders()).ajax;

该方法获得的ajax对象,本质就是axios对象,有axios使用经验的同学完全可以将其动作axios对象使用。

2.1 关于headers方法和buildHeaders方法

EOS应用端的服务接口的调用,都要进行权限验证的,因此ajax请求的时候必须携带当前用户的token。

headers和buildHeaders方法将组装必要的Header信息,在ajax请求的时候携带在header中易通提交到服务端。

其中最重要的就是 Authorization 参数。

2.2 完整的代码

具体的代码例子可见下面:

<template><div class="main-div"><!-- 查询区域 --><div class="div-ke1"><div class="search-bar"><el-button type="primary" @click="doTest1">测试1</el-button></div><div class="list-container"><div > {{ resultInfo }} </div></div></div></div>
</template>
<script>import { AjaxUtil } from 'base/lib'export default {name: 'index',data() {return {resultInfo: ''}},methods: {doTest1() {// ajax请求验证devposToken是否有效const ajax1 = AjaxUtil.headers(AjaxUtil.buildHeaders()).ajax;ajax1.get('/api2/devops/pcm/dict/dict-entrys',{ params: { 'dictTypeId': 'DPS_PJM_PROJECT_TYPE' } }).then(resp1 => {if (resp1.data.code == 0) {this.resultInfo = resp1.data.data;} else {this.resp1Info = resp1.data.code + ':' + resp1.data.msg;}}).catch(err => {this.resp1Info = 'Api请求' + '出现了异常,请联系管理员解决。';});}}
}
</script><style type="scss" scoped>  
.main-div {height: 100%;.div-ke1 {height: 100%;padding: 3px;display: flex;flex-direction: column;}}.search-bar {background-color: #f5f5f5;gap: 10px;padding: 10px;.sb-input1 {max-width: 200px;}}.list-container {flex: 1;overflow-y: auto;}
</style>

3 高开页面get方式ajax请求

代码如下:

<script>import { AjaxUtil } from 'base/lib'export default {name: 'index',data() {return {resultInfo: ''}},methods: {doTest1() {// ajax请求验证devposToken是否有效const ajax1 = AjaxUtil.headers(AjaxUtil.buildHeaders()).ajax;ajax1.get('/api2/devops/pcm/dict/dict-entrys',{ params: { 'dictTypeId': 'DPS_PJM_PROJECT_TYPE' } }).then(resp1 => {if (resp1.data.code == 0) {this.resultInfo = resp1.data.data;} else {this.resp1Info = resp1.data.code + ':' + resp1.data.msg;}}).catch(err => {this.resp1Info = 'Api请求' + '出现了异常,请联系管理员解决。';});}}
}
</script>

get方式提交的参数格式为 {"params":  { 参数键值对 } } 

例子如下:

 ajax1.get('/api2/devops/pcm/dict/dict-entrys',{ params: { 'dictTypeId': 'DPS_PJM_PROJECT_TYPE' } })

返回数据为 response 对象,该对象的data 属性是服务端相应返回的数据。

例子如下:

ajax1.get('/api2/devops/pcm/dict/dict-entrys',{ params: { 'dictTypeId': 'DPS_PJM_PROJECT_TYPE' } }).then(resp1 => {if (resp1.data.code == 0) {this.resultInfo = resp1.data.data;} else {this.resp1Info = resp1.data.code + ':' + resp1.data.msg;}})

4 高开页面Post方式Ajax请求

post方式请求本质上与get方式几乎一样,只是参数直接提供即可,而不需要 params 嵌套一层。

例子如下:

ajax1.post('/api2/devops/pcm/dict/dict-entrys',{ 'dictTypeId': 'DPS_PJM_PROJECT_TYPE' } ).then(resp1 => {if (resp1.data.code == 0) {this.resultInfo = resp1.data.data;} else {this.resp1Info = resp1.data.code + ':' + resp1.data.msg;}})

5 低开页面Ajax请求

相对高开页面的Ajax请求,低开页面提供的Ajax请求更方便,低开页面的Ajax封装的更好。

5.1 简单的get请求

get方式请求的语法如下:

let url = "http://ip:port/路径";
let params = {"key1":"value1","key2":"value2" ....};this.Ajax.get(url, params).then( respData=>{console.log(respData)
})

注意:响应数据与高开响应的数据不同,返回值是服务端相应的数据,而不是response对象。具体的可以自己了解一下response对象和response响应数据。

5.2 不带ip和端口的地址请求

在低开的时候,请求后端服务是不需要ip和端口的,因为前端的地址和后端的地址是一样的。

这时候get或post方法需要加第3个参数false,否则请求的时候路径上自动加上低开前缀。

let url = "/路径";
let params = {"key1":"value1","key2":"value2" ....};this.Ajax.get(url, params,false).then( respData=>{console.log(respData)
})

5.3 完整的例子

例子如下:

let url = '/api2/devops/pcm/template/templates';
let params = {'templateType': 'project','projectScope': 'project'
};
const respData1 = await this.Ajax.get(url, params, false);
if(respData1 .code == 0 ){console.log( respData1.data );
}

5.4 await方式请求

let url = '/api2/devops/pcm/template/templates';
let params = {'templateType': 'project','projectScope': 'project'
};
const respData1 = await this.Ajax.get(url, params, false);
if (respData1.code == 0) {console.log( respData1.data );
}

await方式请求看起来更优雅。

这篇关于普元EOS-微前端调用base基座的ajax的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1102493

相关文章

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

python如何调用java的jar包

《python如何调用java的jar包》这篇文章主要为大家详细介绍了python如何调用java的jar包,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录一、安装包二、使用步骤三、代码演示四、自己写一个jar包五、打包步骤六、方法补充一、安装包pip3 install

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

HTML5 中的<button>标签用法和特征

《HTML5中的<button>标签用法和特征》在HTML5中,button标签用于定义一个可点击的按钮,它是创建交互式网页的重要元素之一,本文将深入解析HTML5中的button标签,详细介绍其属... 目录引言<button> 标签的基本用法<button> 标签的属性typevaluedisabled

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.