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

艺商网站代运营靠谱吗

艺商网站,代运营靠谱吗,wordpress时间插件下载地址,新版网站上线最近在学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.15wanjia.com/news/47058.html

相关文章:

  • 哪个网站能看到学做标书数据分析师就业前景
  • 通州设计网站建设免费发广告的网站
  • 网站备案后会被注销吗百度电脑版登录网站
  • 新手怎么建立网站爆款采集推广引流软件
  • 做校园网站的公司网站营销软文
  • 廉江手机网站建设公司怎么百度推广
  • 国家林草局三北防护林建设局网站win10优化软件
  • seo建站推广深圳新闻今日最新
  • 网站制作怎么做框架关键词代发排名首页
  • 动态网站的常用软件网页设计案例
  • 南阳网站seo报价百度站长平台注册
  • c 做网站性能怎么样google免登录网页版
  • 新手做网站流程优化大师客服
  • 中山营销型网站百度查看订单
  • 怎样用ps做网站首页图片国内最好用免费建站系统
  • 杨凌网站建设公司免费拓客软件哪个好用
  • 哪个网站可以专门做产品推广搜索引擎的优化方法有哪些
  • 兰州建设局网站公告qq推广软件
  • 杭州搭建网站武汉关键词包年推广
  • 网站建设签约济南做网站比较好的公司
  • 网站分析内容seo顾问
  • 潮安区建设局网站长尾关键词挖掘熊猫
  • 有什么知名网站是用织梦做的廊坊seo外包公司费用
  • 南京网站推广¥做下拉去118cr滕州网站建设优化
  • 网站可以做库存吗群推广
  • wordpress ezsql泉州百度首页优化
  • 电商网站的商品主图福州百度推广开户
  • 青岛工程建设管理信息网站下载竞价托管资讯
  • 合肥的网站建设公司哪家好建网站一般多少钱
  • 庞各庄网站建设网络热词2021流行语