适用于:

  1. 小程序
  2. app
  3. H5

安装 uni-request

npm install uni-request --save

封装 uni-request (utils => request.js)

import uniRequest from 'uni-request';


uniRequest.defaults.baseURL = process.env.NODE_ENV == 'development' ? 'XXXXXX' :
	'XXXXXX'  //接口根据环境自己写
uniRequest.defaults.headers['X-Requested-With'] = 'XMLHttpRequest'
uniRequest.defaults.headers['token'] = uni.getStorageSync('token') || ''
uniRequest.defaults.headers.post['Content-Type'] = 'application/json';

uniRequest.interceptors.response.use(res => {
	if (typeof res.data !== 'object') {
		uni.showModal({
			title: '服务器端异常',
		});
		return Promise.reject(res)
	}
	if (res.data.code == 999) {
		uni.reLaunch({
			url: '/pages/login/login'
		});
	}
	if (res.data.code != 100) {
		if (res.data.message) {
			uni.showModal({
				title: res.data.message,
			});
		}
		return Promise.reject(res.data)
	}
	return res.data
})


export default uniRequest


接口文件 (server=> home.js)

import requset from '../utils/request.js'

export function getHome() {
  return requset.post('/merber/index');
}

页面使用

<template>
	<view class="content">
		<button type="default" @click="test">测试接口</button>
	</view>
</template>

<script>
	import {
		getHome
	} from "../../server/home.js";
	export default {
		methods: {
			async test() {
				const data = await getHome();
				console.log(data);
			},
		}
	}
</script>

完工!

提供的请求方法(可自己封装)

uniRequest.request(config)
uniRequest.get(url[, config])
uniRequest.delete(url[, config])
uniRequest.head(url[, config])
uniRequest.options(url[, config])
uniRequest.post(url[, data[, config]])
uniRequest.put(url[, data[, config]])
uniRequest.patch(url[, data[, config]])
Logo

欢迎加入 MCP 技术社区!与志同道合者携手前行,一同解锁 MCP 技术的无限可能!

更多推荐