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

宁波网站建设怎么样丽水网站seo

宁波网站建设怎么样,丽水网站seo,照片做视频ppt模板下载网站,深圳网络推广代理最近在学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.ds6.com.cn/news/64691.html

相关文章:

  • 中文手机网站设计案例最成功的网络营销案例
  • 网站开发遇到的问题seo网站推广软件
  • 可视化网站模板网络营销的概念及内容
  • 昆山智能网站建设站长统计在线观看
  • 做单页网站容易排名吗福建百度代理公司
  • wordpress企业网站建设百度免费安装下载
  • 视频 播放网站怎么做的千锋教育官网
  • 网站ui界面设计滨州网站seo
  • 企业网站后台模板360推广怎么收费
  • h5商城网站怎么做的淘宝推广方式
  • 山乙建设公司网站网站seo外链平台
  • wordpress seo title福州seo按天付费
  • 网站建设规划书 百度文库seo网站推广是什么意思
  • 浠水做网站的独立站推广
  • 临沭有做网站的吗网站交易
  • 网站专题制作流程百度联盟官网
  • 中国造价信息网官网成都seo工程师
  • 网站维护的主要内容安卓优化大师下载
  • 北京做胃镜哪好德胜门网站I荥阳网络推广公司
  • 软件产品如何做网站推广广东省广州市佛山市
  • 网站上传大马后怎么做seo关键词排名优
  • 企业网站的规划与建设ppt营销型网站建设服务
  • 建设网站设计重庆高端网站seo
  • 安徽省建设工程信息网官方网站培训
  • 改变网站的域名空间app001推广平台
  • php做的网站怎么打开关键词seo是什么
  • 手机网站开发按返回弹出提示窗口长沙网络推广外包
  • 南宁营销型网站专家seo发帖软件
  • 进入城乡建设网站怎么竣工备案谷歌搜索入口
  • 嘉兴注册公司新网站seo外包