Vue后台开发实例教程(四)Vue全局注册API接口调用
本实例教程是.net core 系列实例开发教程-权限管理系统前端开发教程,使用PanJiaChen写的Vue后台模板。
本文源码下载地址:http://www.80cxy.com/Blog/ResourceView?arId=202403191532545995NAAqJh
系列教程地址:http://www.80cxy.com/Blog/ArticleView?arId=202403191517574161ay3s5V
为方便接口调用,本文实现全局注册API接口,首先在scr/api文件夹下面新建system.js接口调用文件,然后scr/api/index.js对外统一暴露。在main.js入口文件做全局配置。相关代码如下:
一、system.js接口文件
import request from '@/utils/request'
/***********用户管理************/
//管理用户登录
export function login(data) {
return request({
url: '/api/AdminLogin/AdminLogin',
method: 'post',
data
})
}
//获取用户信息
export function getInfo(token) {
return request({
url: '/api/AdminLogin/GetUserInfo',
method: 'get',
})
}
//退出登录
export function logout() {
return request({
url: '/api/AdminLogin/LogOut',
method: 'post'
})
}
/***********菜单管理************/
//获取一级分类数据接口
export const reqMenuTreeList = ()=> request({url: '/api/System/GetMenuTreeList',method:'get'});
//添加、修改保存
export const reqAddOrUpdateMenu=(model)=>{
// 带给服务器数据携带ID--修改
if(model.id){
return request({url:'/api/System/EditMenu',method:'put',data:model})
}
else
{
//新增人员
return request({url:'/api/System/AddMenu',method:'post',data:model})
}
}
//删除菜单
export const reqDeleteMenu = (id) => {
return request({ url: `/api/System/DeleteMenu?id=${id}`, method: 'delete' })
}
二、index.js统一对外暴露文件
import * as system from './system';
//对外暴露对象
export default{
system,
}
三、main.js配置代码
Vue.config.productionTip = false //引入相关API请求接口 import API from '@/api'; //组件实例的原型的原型指向的是Vue.prototype //任意组件可以使用API相关的接口 Vue.prototype.$API = API;
四、组件调用接口代码
async getPageList() {
let result = await this.$API.system.reqMenuTreeList();
if (result.code == 200) {
this.list = result.data.rows;
this.expandKeys = [this.list[0].id];
}
},
学习交流

猜您可能还喜欢
- CERT_HAS_EXPIRED错误如何解决(3022)
- Js异步async、await关键字详细介绍(lambda表达式中使用async和await关键字)(2667)
- Vue 2.x + Element后台模板开发教程(三)后台首页模板设计(1314)
- vuex中 this.$store.dispatch() 与 this.$store.commit()方法的区别(1289)
- Error: Cannot find module ‘chokidar‘ 解决方法(1280)
- Vue后台开发实例教程(二)Title修改及左侧菜单修改(1196)
- Vue 2.x + Element后台模板开发教程(一)(1143)
- vuejs中如何使用axios调用后台接口(1135)
- vue.js初探(一)vue.js全家桶介绍(941)
- vue.js初探(三)vue页面结构(941)
评论列表
发表评论
文章分类
文章归档
- 2025年3月 (1)
- 2024年6月 (2)
- 2024年5月 (2)
- 2024年4月 (4)
- 2024年3月 (30)
- 2024年1月 (4)
- 2023年12月 (2)
- 2023年11月 (4)
- 2023年10月 (4)
- 2023年9月 (6)
- 2023年3月 (2)
- 2023年2月 (1)
- 2023年1月 (1)
- 2022年12月 (1)
- 2022年9月 (21)
- 2022年8月 (10)
- 2022年7月 (3)
- 2022年4月 (1)
- 2022年3月 (13)
- 2021年8月 (1)
- 2021年3月 (1)
- 2020年12月 (42)
- 2020年11月 (7)
- 2020年10月 (5)
- 2020年8月 (1)
- 2020年6月 (1)
- 2020年3月 (2)
- 2019年12月 (8)
- 2019年11月 (3)
- 2019年9月 (1)
- 2019年4月 (1)
- 2019年3月 (6)
- 2019年2月 (1)
- 2018年7月 (7)
阅读排行
- 1.asp.net mvc内微信pc端、H5、JsApi支付方式总结(5920)
- 2.Windows 10休眠文件更改存储位置(4013)
- 3.各大搜索网站网站收录提交入口地址(3506)
- 4.windows 10安装myeclipse 10破解补丁cracker.jar、run.bat闪退解决办法(3482)
- 5.ECharts仪表盘实例及参数使用详解(3465)
- 6.华为鸿蒙系统清除微信浏览器缓存方法(3258)
- 7.HTML5 WebSocket与C#建立Socket连接实现代码(3222)
- 8.CERT_HAS_EXPIRED错误如何解决(3022)
- 9.Js异步async、await关键字详细介绍(lambda表达式中使用async和await关键字)(2667)
- 10.HBuilder编辑器格式化代码(2430)
