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

安徽网站建设天锐科技广州网站建设技术外包

安徽网站建设天锐科技,广州网站建设技术外包,社区网站开发进度表,移动网站开发面试题最近在学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.yayakq.cn/news/474735/

相关文章:

  • 蚂蚁网站建设wordpress落地页模板
  • 虚拟主机建网站广州网站开发培训学校
  • 微信公众号绑定网站选择建设网站公司要注意什么
  • 萧山建设信用网站东莞营销网站建设直播
  • 电子商务网站建设下载seo招聘信息
  • 2017 如何做网站优化protected wordpress login
  • 网站做pc铭誉摄影网站
  • 学校建设微网站的方案设计郑州市金水区
  • 天水市建设局网站长春网站建设建站系统
  • 营销型网站效果不好设计公司企业网站详情
  • 用台式机做网站服务器wordpress首页编辑
  • html教程网站网站每年维护费用
  • 安丘市住房与城市建设路网站谷歌地图下载
  • 上海公司网站建设服务建设企业网站模板
  • 模板建站教程营销公司的营业范围
  • 深圳福田华丰大厦网站建设网站收录查询站长工具
  • 北京代理记账财务公司优化师
  • 江苏宏澄建设有限公司网站专题网站建设解决方案
  • 凡客诚品的网站特色淘宝上的网站建设
  • 网站频繁改版网络营销做得比较成功的案例
  • 安微凤阳县建设局网站怀化市建设局网站
  • 个体工商网站备案修改wordpress注册页
  • 如何自己建一个网站博物馆门户网站建设目标
  • 吉林整站优化网页设计难还是网站建设南
  • 淘宝店网站建设规划书wordpress热门插件
  • 北京网站建设哪家便宜小程序商城服务好的商家
  • 版权申请网站网站首页全屏怎么做
  • 做网站推广好做么wordpress 更好 知乎
  • dede酒业企业网站模板哪些网站是用php做的
  • 心雨在线高端网站建设网页设计长沙seo排名收费