位置: IT常识 - 正文

uni-app,vue3接口请求封装(uni vuex)

编辑:rootadmin
uni-app,vue3接口请求封装 uni-app接口,全局方法封装

推荐整理分享uni-app,vue3接口请求封装(uni vuex),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:uniapp 使用vue3,uni-app使用vuex,uni app vue3,uni app vue3,uni vue3,uni vue3,uni app vue3,uni vue3,内容如对您有帮助,希望把文章链接给更多的朋友!

1.在根目录创建一个api文件,在api文件夹中创建api.js,baseUrl.js和http.js文件

2. baseUrl.js文件代码

export default "https://XXXX.test03.qcw800.com/api/"

3.http.js文件代码

export function https(opts, data) {let httpDefaultOpts = {url: opts.url,data: data,method: opts.method,header: opts.method == 'get' ? {'X-Requested-With': 'XMLHttpRequest',"Accept": "application/json","Content-Type": "application/json; charset=UTF-8"} : {'X-Requested-With': 'XMLHttpRequest','Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'},dataType: 'json',}let token = uni.getStorageSync('token');if (token != undefined && token != null && token != '') {httpDefaultOpts.header.Authorization = 'Bearer ' + token;}let promise = new Promise(function(resolve, reject) {uni.request(httpDefaultOpts).then((res) => {// console.log(res, '成功')if(res.statusCode == 401){uni.clearStorageSync();}resolve(res)}).catch((response) => {// console.log(response, '失败')reject(response)})})return promise}

4.api.js文件代码

export const rootUrl="https://ssss.test03.qcw800.com"; //其他接口域名export const baseUrl= rootUrl + "api/";export const api = {// 获取验证码guest:{ url: rootUrl + '/api/public/guest',method: 'GET'},// 登录login:{ url: rootUrl + '/api/user/login',method: 'GET'}}

5.在main.js文件中引入接口文件

import App from './App'// #ifndef VUE3import Vue from 'vue'Vue.config.productionTip = false; //设置为 false ,可以阻止 vue 在启动时生成生产提示App.mpType = 'app'const app = new Vue({...App})app.$mount()// #endif// #ifdef VUE3import {createSSRApp} from 'vue'import {toast,nav,checkMobile,onuploadFile} from '@/api/functions.js'import {api,rootUrl} from '@/api/api.js' // API 链接import {https} from '@/api/http.js' // 请求方式中间件import navigationBar from '@/components/navigationBar.vue'import publicContext from '@/components/publicContext.vue'export function createApp() {const app = createSSRApp(App)app.component('navigationBar', navigationBar);app.component('publicContext', publicContext);app.config.globalProperties.$toast = toast;app.config.globalProperties.$nav = nav;app.config.globalProperties.$add = add;app.config.globalProperties.$checkMobile = checkMobile;app.config.globalProperties.$isEmpty = isEmpty;app.config.globalProperties.$formatFloat = formatFloat;app.config.globalProperties.$api = api;app.config.globalProperties.$rootUrl = rootUrl;app.config.globalProperties.$http = https;app.config.globalProperties.$imgUrl = 'https://qianchao-sheke.oss-cn-hangzhou.aliyuncs.com/'return {app}}// #endifuni-app,vue3接口请求封装(uni vuex)

6.接口请求

this.$http(this.$api.messageList,{api_token:uni.getStorageSync('token'),pageSize:10, page:1}).then(res=>{console.log(res,'返回参数');})

另外,封装的全局方法,上面第五步在main文件中已经引入,

export function toast(title){uni.showToast({icon:'none',title:title,position:'bottom',})}//校验手机格式 export function checkMobile(mobile){return RegExp(/^1[34578]\d{9}$/).test(mobile);}export function nav(url,type=0){if(type == 0){uni.navigateTo({url:url})}else if(type == 1){uni.switchTab({url:url})}else if(type == 3){uni.navigateBack({})}else if(type == 4){uni.redirectTo({url: url});}else if(type == 5){uni.reLaunch({url});}}// 上传图片export function onuploadFile(){var _this = this;uni.chooseImage({count: 1, //默认9sizeType: ['original', 'compressed'],sourceType: ['album', 'camera'],success: (res) => {// console.log(res.tempFilePaths,'图片的本地文件路径列表',_this.$rootUrl);uni.uploadFile({url: _this.$rootUrl +'/api/public/upload',//上传图片的地址filePath: res.tempFilePaths[0],//这里是图片的本地文件路径列表(选择图片成功的时候可以拿到,在上边的success回调中res.tempFilePaths即可拿到)name: 'file',//上传的名字叫啥都行// headers: {// accessToken:'' //可以设置你的请求头的token噢// },success(res) {//上传成功的回调// console.log('上传成功',res)var data = JSON.parse(res.data);return data.data[0];},fail(err){console.log(err,'上传失败');},complete(result){console.log(result,'上传结果');}})}});}vue3接口请求封装

1.在项目中安装axios

npm install --save axios vue-axios

2.在src文件夹下创建request文件夹,及index.js和api.js文件

3.index.js文件代码

import axios from "axios";//创建一个axios的对象import { useRouter } from "vue-router";import { inject } from "vue";//生成一个axios的实例const http=axios.create({baseURL:"https://xxxx.test03.qcw800.com",// baseURL会在发送请求的时候拼接在url参数前面timeout:6000,//请求超时});// http.defaults.headers['api_token'] = localStorage.getItem('token') || '' //在请求头中传入tokenhttp.interceptors.request.use(config => { // console.log(config,'请求拦截'); return config;}, err => { return Promise.reject(err)})//响应拦截器http.interceptors.response.use(response => {//console.log(response,'响应拦截');return response; }, err => { return Promise.reject(err) })export default http;//导出

 4.api.js文件代码

//导入request.jsimport request from "@/request/index";//登录export const login = (params) => request.get("/api/user/login",{params});//获取个人信息export const userDetail = (params) => request.get("/api/user/detail",{params});//方法二 在api文件里出来异步请求// export const getCategory=async()=>{// const res=await request.get(`/category/`);// return res.data;// };

5.接口请求

<script>import { defineComponent,onMounted } from 'vue'import { userDetail } from '@/request/api'export default defineComponent({ setup() { onMounted(()=>{ userDetail({api_token:localStorage.getItem('token')}).then(res=>{ console.log(res,'个人信息'); }) }) }})</script>

会了不!!

 等会还有解决跨域问题,代理代码

const { defineConfig } = require('@vue/cli-service')module.exports = defineConfig({ transpileDependencies: true, devServer: { port: 8080, // 端口号 open: false, //配置是否自动启动浏览器 https: false,// https:{type:Boolean}是否启用https proxy: { // 代理 "/api": { target: "https://xxxx.test03.qcw800.com", //要代理访问的路径 changeOrigin: true,//开启代理:在本地会创建一个虚拟服务端,然后发送请求的数据,并同时接收请求的数据,这样服务端和服务端进行数据的交互就不会有跨域问题 ws: true,//是否启用websockets,用不到可设为false pathRewrite: { "^/api": ""//这里理解成用'/api'代替target里面的地址,比如我要调用'http://192.168.0.45:8088/user/getuserlist',直接写'/api/user/getuserlist'即可 } } } },})
本文链接地址:https://www.jiuchutong.com/zhishi/297693.html 转载请保留说明!

上一篇:使用LabVIEW 实现物体识别、图像分割、文字识别、人脸识别等深度视觉(labview实例教程)

下一篇:vue项目 移动端适配——rem(vue项目移动端怎么做适配)

  • 抖音极速版怎么扫一扫(抖音极速版怎么没有签到领金币了)

    抖音极速版怎么扫一扫(抖音极速版怎么没有签到领金币了)

  • 抖音怎么一次性删除所有聊天记录(抖音怎么一次性隐藏所有作品)

    抖音怎么一次性删除所有聊天记录(抖音怎么一次性隐藏所有作品)

  • 1分钟视频怎么发朋友圈(1分钟视频怎么收费)

    1分钟视频怎么发朋友圈(1分钟视频怎么收费)

  • 域名年龄对seo的影响(域名年龄对seo的影响大吗)

    域名年龄对seo的影响(域名年龄对seo的影响大吗)

  • 手机摔碎了里面的资料怎么办(手机摔碎了里面的东西能导出来吗)

    手机摔碎了里面的资料怎么办(手机摔碎了里面的东西能导出来吗)

  • 抖音照片怎么保存到相册(抖音照片怎么保存视频)

    抖音照片怎么保存到相册(抖音照片怎么保存视频)

  • 抖音流量池分配规则(抖音流量池分配规则图)

    抖音流量池分配规则(抖音流量池分配规则图)

  • word双蓝线是什么意思(word中蓝色双横线)

    word双蓝线是什么意思(word中蓝色双横线)

  • 微信运动赞可以撤回吗(微信运动赞可以撤回吗,对方能发现吗)

    微信运动赞可以撤回吗(微信运动赞可以撤回吗,对方能发现吗)

  • 笔记本硬盘和台式机硬盘通用吗(笔记本硬盘和台式机硬盘性能差距)

    笔记本硬盘和台式机硬盘通用吗(笔记本硬盘和台式机硬盘性能差距)

  • 手机号被锁有几个原因(手机号被锁了是什么情况)

    手机号被锁有几个原因(手机号被锁了是什么情况)

  • 设置仅聊天对方知道吗(设置仅聊天对方能看到朋友圈背景吗)

    设置仅聊天对方知道吗(设置仅聊天对方能看到朋友圈背景吗)

  • 钉钉人脸识别可以用照片吗(钉钉人脸识别可以远程打卡吗)

    钉钉人脸识别可以用照片吗(钉钉人脸识别可以远程打卡吗)

  • 硬盘密码忘了怎么办(硬盘密码忘了怎么解锁)

    硬盘密码忘了怎么办(硬盘密码忘了怎么解锁)

  • 网络中各节点的互联方式叫做网络的什么(网络各节点的互联方式叫做)

    网络中各节点的互联方式叫做网络的什么(网络各节点的互联方式叫做)

  • 打印机扫描功能啥意思(打印机扫描功能突然不能用了)

    打印机扫描功能啥意思(打印机扫描功能突然不能用了)

  • 耳机放洗衣机里洗了怎么办(耳机放洗衣机里洗过后还能用吗)

    耳机放洗衣机里洗了怎么办(耳机放洗衣机里洗过后还能用吗)

  • 手机怎么装电脑系统(手机怎么装电脑系统教程)

    手机怎么装电脑系统(手机怎么装电脑系统教程)

  • 小米9超级夜景在哪里(小米9超级夜景怎么关)

    小米9超级夜景在哪里(小米9超级夜景怎么关)

  • 电脑不用待机怎样恢复(电脑不用怎么待机)

    电脑不用待机怎样恢复(电脑不用怎么待机)

  • 零轴线是什么意思(零轴线是哪条线)

    零轴线是什么意思(零轴线是哪条线)

  • 艺术字位置水平在哪里(艺术字位置水平6cm左上角怎么设置)

    艺术字位置水平在哪里(艺术字位置水平6cm左上角怎么设置)

  • 华为mate20后盖什么材质(华为mate20后盖碎了怎么打开)

    华为mate20后盖什么材质(华为mate20后盖碎了怎么打开)

  • 行距28磅怎么设置(行距28.9磅怎么设置)

    行距28磅怎么设置(行距28.9磅怎么设置)

  • 天猫手机如何分期(天猫怎么分期买手机教程)

    天猫手机如何分期(天猫怎么分期买手机教程)

  • 最新解决方法:Win11搜索框不能使用怎么办(wifan)

    最新解决方法:Win11搜索框不能使用怎么办(wifan)

  • python中用OpenCV在图像添加文本(opencv python)

    python中用OpenCV在图像添加文本(opencv python)

  • 280元抵减税控设备
  • 解聘补偿金赔偿标准2023
  • 劳务派遣人员保险由谁缴纳
  • 工资出现负数怎么申报个税
  • 核定征收率怎么算的
  • 报销单用法
  • 企业为个人承担的个人部分社保
  • 房地产中的存货是什么意思
  • 个人减税具体政策
  • 营改增举例说明
  • 无形资产除了专利还有什么
  • 增值税发票可以抵税吗
  • 免税企业收到的专用发票要怎么转出
  • 旅游业务开什么发票
  • 小规模纳税人增值税超过30万怎么纳税
  • 房产评估增值部门有哪些
  • 上年留抵增值税怎么做账
  • 财产保险费计入什么科目
  • 车位租赁费和房屋租赁能开一张发票吗
  • 现金采购怎么算
  • 企业季度所得税可以弥补以前年度亏损吗
  • 退休人员再就业受伤算工伤吗
  • vue3如何
  • 固定资产计提折旧的方法
  • 工程长期停工
  • linux安装方式有
  • 公司多缴税款超过3年怎么办
  • pc是什么文件
  • php socket_write
  • 马齿笕对什么病最有效?
  • 房地产开发企业涉及哪些税
  • php需要的软件
  • php获取post请求参数
  • 小规模纳税人的条件
  • java webflux
  • 基于stm32f103c8t6的毕业设计
  • vue cannot set property
  • 无人驾驶基础知识
  • python答疑
  • 实现视图
  • 如何一次性删除微信账单记录
  • 公允价值变动损益
  • 非财政补助结余分配和非财政拨款结余分配
  • 预收账款是否要缴纳增值税
  • 契税计入会计利润总额吗
  • 外来原始凭证审核内容
  • 劳务派遣业务的特点
  • 年金现值和终值的关系
  • 科目余额表和资产负债表的期末余额不一样,怎么办
  • 进仓费开票是几个点
  • 存货跌价准备什么科目
  • 城建税的征收范围不包括农村
  • 固定资产报废时,后续未折旧额计入哪里
  • 定额转查账征收
  • 可以抵扣土地增值税的项目
  • 收到利息的会计凭证
  • 企业所得税汇算表
  • 股东的投资款可以直接私人银行卡转账吗
  • 母公司及子公司增资
  • 电子银行回单可以作为凭证吗
  • 处置固定资产的增值税怎么处理
  • 购买食品应注意哪些问题?
  • 投资性房地产是固定资产吗
  • 零售货品
  • macoshosts文件位置
  • linux操作系统的发行版本有哪些
  • window配置在哪
  • win8.1流畅吗
  • win10虚拟机无法安装
  • 影子系统作用
  • excel表格文本形式在哪里
  • pycharm下载安装
  • js 括号函数
  • node 微信公众号开发
  • linux查看端口号占用
  • 四川税务局网上办税
  • 怎样在江苏智慧人社上停保
  • 北京大兴开发区房价
  • 增值税普票十万怎么开
  • 李民基
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设