[uniapp]请求数据与接口封装

不封装时的请求

  1. 在methods定义getSwiper函数
		methods:{
			//获取轮播图数据
			getSwiper(){
				console.log("获取轮播图数据")
				uni.request({
					url:'http://localhost:8082/api/getlunbo',
					success:res=>{
						console.log(res)
						if(res.data.status!==0){
							return uni.showToast({
								title:"获取数据失败"
							})
						}
						this.swipers=res.data.message
					}
				})
			}
		}
  1. 在onload触发getSwiper函数
	onLoad() {
			this.getSwiper()
		},
  1. 在data函数返回一个本地数组
	data() {
			return {
				swipers: []
			}
		},

封装函数

  1. 在util下的api.js
const BASE_URL = 'http://localhost:8082'
export const myRequest = (options)=>{
	return new Promise((resolve,reject)=>{
		uni.request({
			url:BASE_URL+options.url,
			method: options.method || 'GET',
			data: options.data || {},
			success: (res)=>{
				if(res.data.status !== 0) {
					return uni.showToast({
						title: '获取数据失败'
					})
				}
				resolve(res)
			},
			fail: (err)=>{
				uni.showToast({
					title: '请求接口失败'
				})
				reject(err)
			}
		})
	})
}
  1. 引入封装中暴露的模块
import { myRequest } from './util/api.js'
  1. 挂载到全局可用
Vue.prototype.$myRuquest = myRequest
  1. 在需要请求的页面发送请求
	methods:{
			//获取轮播图数据
			async getSwiper(){
				const res = await this.$myRuquest({
									url: '/api/getlunbo'
								})
				console.log(res)
				//把轮播图数据存到本地
				this.swipers=res.data.message
			}
		}

获取成功的效果:
在这里插入图片描述

ctrl+c停了接口后的效果
在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值