当前位置: 首页 > news >正文

wordpress时间几天前攀枝花seo

wordpress时间几天前,攀枝花seo,明起3天洛阳市开展区域核酸检测,深圳官网设计最近在学Uniapp,到封装请求的时候本来还想用axios,但是看到一些教学视频有更简单的方法, 基于uni的拦截器和Promise封装的请求函数 但是他们是用TS写的,还没学到TS,我就把JS写了,最终也是请求成功 // src/…

最近在学Uniapp,到封装请求的时候本来还想用axios,但是看到一些教学视频有更简单的方法,

基于uni的拦截器和Promise封装的请求函数

但是他们是用TS写的,还没学到TS,我就把JS写了,最终也是请求成功

// src/utils/http.jsimport { useUserStore } from "../stores/modules/user"// 请求基地址
const baseURL = 'https://pcapi-xiaotuxian-front-devtest.itheima.net'// 拦截器配置
const httpInterceptor = {// 拦截前触发invoke(options) {// 1. 非 http 开头需拼接地址if (!options.url.startsWith('http')) {options.url = baseURL + options.url}// 2. 请求超时options.timeout = 10000// 3. 添加小程序端请求头标识options.header = {'source-client': 'miniapp',...options.header,}// 4. 添加 token 请求头标识const userStore = useUserStore()const token = userStore.getToken() ? userStore.getToken() : ''if (token) {options.header.Authorization = token}},
}// 拦截 request 请求
uni.addInterceptor('request', httpInterceptor)
// 拦截 uploadFile 文件上传
uni.addInterceptor('uploadFile', httpInterceptor)export const http = (options) => {return new Promise((resolve, reject) => {uni.request({...options,success(res) {if (res.statusCode >= 200 && res.statusCode < 300){resolve(res.data)} else if ( res.statusCode === 401){const userStore = useUserStore()userStore.removeToken()uni.navigateTo({ url: '/pages/login/login' })reject(res)} else {uni.showToast({icon: 'none',title: (res.data).msg || '请求错误',})reject(res)}},fail(err) {uni.showToast({icon: 'none',title: '请求失败',})reject(err)}})})
}

组件引入http方法进行请求

最后附上TS的写法,感觉其实差不多,只是用TS语法进行了一下泛型的判断

// src/utils/http.ts// 请求基地址
const baseURL = 'https://pcapi-xiaotuxian-front-devtest.itheima.net'// 拦截器配置
const httpInterceptor = {// 拦截前触发invoke(options: UniApp.RequestOptions) {// 1. 非 http 开头需拼接地址if (!options.url.startsWith('http')) {options.url = baseURL + options.url}// 2. 请求超时options.timeout = 10000// 3. 添加小程序端请求头标识options.header = {'source-client': 'miniapp',...options.header,}// 4. 添加 token 请求头标识const memberStore = useMemberStore()const token = memberStore.profile?.tokenif (token) {options.header.Authorization = token}},
}// 拦截 request 请求
uni.addInterceptor('request', httpInterceptor)
// 拦截 uploadFile 文件上传
uni.addInterceptor('uploadFile', httpInterceptor)type Data<T> = {code: stringmsg: stringresult: T
}
// 2.2 添加类型,支持泛型
export const http = <T>(options: UniApp.RequestOptions) => {// 1. 返回 Promise 对象return new Promise<Data<T>>((resolve, reject) => {uni.request({...options,// 响应成功success(res) {// 状态码 2xx,参考 axios 的设计if (res.statusCode >= 200 && res.statusCode < 300) {// 2.1 提取核心数据 res.dataresolve(res.data as Data<T>)} else if (res.statusCode === 401) {// 401错误  -> 清理用户信息,跳转到登录页const memberStore = useMemberStore()memberStore.clearProfile()uni.navigateTo({ url: '/pages/login/login' })reject(res)} else {// 其他错误 -> 根据后端错误信息轻提示uni.showToast({icon: 'none',title: (res.data as Data<T>).msg || '请求错误',})reject(res)}},// 响应失败fail(err) {uni.showToast({icon: 'none',title: '网络错误,换个网络试试',})reject(err)},})})
}

http://www.dt0577.cn/news/21761.html

相关文章:

  • 我想花钱做网站百度seo算法
  • 玉林住房和城乡规划建设委员会网站免费推广网站大全
  • 大良营销网站建设流程免费加客源
  • cdn网络对网站开发有影响吗企业官方网站有哪些
  • 网站做1920px好吗网站seo方案
  • 淘宝客服推销做网站的技巧百度站长之家工具
  • 网站ftp管理工具关键词挖掘爱站网
  • 河北网络建站谷歌sem推广
  • 外贸流程全步骤流程图seo学习论坛
  • 制作免费个人网页漯河搜狗关键词优化排名软件
  • 手机怎么建网站2345网止导航
  • 深圳制作外贸网站网站排名首页前三位
  • 闭站保护对网站影响seo排名官网
  • 作业提交免费网站seo发帖软件
  • 佛山专业网站制作设计爱站网查询
  • 台州网站推广软件外包网站
  • wordpress 显示文章数量教程seo推广排名网站
  • 学做网站需要多长时间朝阳网站建设公司
  • 网站建设 怎么设置在线客服博客
  • 大丰企业做网站多少钱好的推广方式
  • 深圳做网站建设的公司网站关键词推广工具
  • 运营好的网站制作中心互联网营销专家
  • 前端电商网站开发周期优化培训课程
  • 国家工商总局查询平台张家口网站seo
  • 烟台网站主关键词seo快速优化文章排名
  • 广告设计与制作用什么软件seo优化服务是什么
  • 顺德人做多上哪个网站广州seo优化效果
  • 广州有几个区几个县级市企业网站seo
  • wap网站模式国内新闻最新消息今天
  • 呼伦贝尔哪里做网站做网络推广有哪些平台