uniapp---request请求及其封装

前端向后台发送获取数据网络请求,使用uni.request()   https://uniapp.dcloud.io/api/request/request

一、uni.request请求

methods:{
    getData(){
		uni.request({
			url:'https://www.example.com/request', //仅为示例,并非真实接口地址。
            data: {
                text: 'uni.request'
            },
            header: {
                'custom-header': 'hello' //自定义请求头信息
            },
			success:res=> {
			    console.log(res)
			    if(res.data.status!==0){
				    return uni.showToast({
						title:"数据获取失败"
				    })
			    }
			    this.data=res.data.messege
			}
		})
	}
}

二、封装uni.request请求

网络请求一般都会封转成一个公用的工具类,专门处理网络请求。这样集中处理接口地址,清晰、方便且高效。具体如下:

(1)在项目下新建【http】文件夹,新建【api.js】文件

const BASE_URL="http://192.168.34.121:8080"
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)=>{
				resolve(res)
			},
			fail:(err)=>{
				uni.showToast({
					title:"请求接口失败"
				})
				reject(err)
			}
		})
	})
}

(2)在【main.js】将request请求挂在在原型链上(全局使用)

import {myRequest} from "./http/api.js"

// 挂载全局
Vue.prototype.$myRequest=myRequest

(3)在页面或组件中通过【this.$myRequest()】使用封装好的请求接口

methods:{
  saveData(){
	var param={
					cardImage:this.cardImage,
					cardInfo:this.cardInfo,
					type:this.type
				}
				console.log(param)
				this.$myRequest({
					url:"card/save",
					method:"POST",
					data:param
				}).then(res=>{
					console.log(res)
					if(res.data.respCode=="00000"){}else{}
					uni.showToast({title:res.data.respDesc,icon:"none"})
					uni.navigateTo({
						url:"/pages/index/index"
					})
				}).catch(err=>{
					console.log(err)
				})
}

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
uniapp是一款跨平台的开发框架,可以用于同时开发iOS、Android和Web应用程序。而luch-requestuniapp中一个常用的网络请求库,用于发送HTTP请求并处理响应。 luch-request封装uni.request方法,提供了更加简洁和易用的接口,使得发送网络请求变得更加方便。它支持Promise风格的异步请求,可以发送GET、POST等各种类型的请求,并且可以设置请求头、请求参数、超时时间等。 以下是luch-request的一些主要特性和使用方法: 1. 支持拦截器:可以在请求发送前和响应返回后进行拦截和处理。 2. 支持全局配置:可以在全局设置请求的默认参数,如请求头、超时时间等。 3. 支持取消请求:可以取消正在进行的请求。 4. 支持文件上传和下载:可以发送文件上传请求,并支持进度监听。 5. 支持自动刷新token:可以在请求失败时自动刷新token并重新发送请求。 使用luch-request封装发送网络请求的步骤如下: 1. 安装luch-request:在uniapp项目中的package.json文件中添加依赖,并执行npm install命令进行安装。 2. 引入luch-request:在需要发送请求的页面或组件中引入luch-request库。 3. 创建实例:通过new关键字创建一个luch-request实例。 4. 发送请求:使用实例的request方法发送请求,并设置请求的相关参数。 5. 处理响应:在请求成功后,可以通过then方法获取响应数据;在请求失败后,可以通过catch方法捕获错误信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值