一、使用axios获取后端数据并使用
1.对axios进行封装 network/request.js
data:image/s3,"s3://crabby-images/bada8/bada832b9674641f392fc83cf917cc41aa39040b" alt="在这里插入图片描述"
import axios from 'axios'
import nprogress from 'nprogress'
import "nprogress/nprogress.css"
const requests = axios.create({
baseURL:'/api',
timeout:5000
});
requests.interceptors.request.use((config)=>{
nprogress.start()
return config;
})
requests.interceptors.response.use((res)=>{
nprogress.done()
return res.data;
},(err)=>{
});
export default requests;
对api进行统一管理 network/index.js
data:image/s3,"s3://crabby-images/0ab56/0ab565a22c66487cc97dd922f282931d561bbf28" alt="在这里插入图片描述"
import requests from './request';
import mockrequest from './mockrequest'
export const getCategoryList = () => requests({url:'/product/getBaseCategoryList',method:'get'});
export const swiper = () => mockrequest({url:'/swiper',method:'get'});
2.在要获取的数据页面通过dispatch访问仓库里面actions(actions里面可以处理异步,向服务器发送请求)
mounted() {
this.$store.dispatch("getSwiperList");
}
data:image/s3,"s3://crabby-images/5ffb3/5ffb395f4fdb56147a77570ff79ebbaf76b60fef" alt="在这里插入图片描述"
3.在仓库store里面的actions里面导入network里需要的模块,在actions里面处理获取服务器返回的数据的业务逻辑。 store/index.js
async categoryList({commit}){
let result = await getCategoryList();
if(result.code==200){
commit('CATEGORYLIST',result.data)
}
},
data:image/s3,"s3://crabby-images/32eb6/32eb6afa3f227c554c8fa8569c7a7300f6a45487" alt="在这里插入图片描述"
4.在mutations中修改state中的数据
CATEGORYLIST(state,categoryList){
state.categoryList = categoryList
},
data:image/s3,"s3://crabby-images/f10de/f10de996bff22fafa13d7a13f41ac31338514dc9" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/e4911/e491134db3f584f7c338b86d4ea8037014bf4de7" alt="在这里插入图片描述"
5.从仓库拿数据
import {mapState} from 'vuex';
computed:{
...mapState({
swiperList:(state)=>{
console.log(state)
return state.swiper
}
})
}
data:image/s3,"s3://crabby-images/3a4e6/3a4e6082ab278be26a735346f2928b1c26541b09" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/534a8/534a8f9b67fb62665521dbeef0d1b9f8ce8bf8c2" alt="在这里插入图片描述"
6.然后就可以使用啦!
二、使用Mock.js 1.先用npm安装mockjs 2.准备好json格式的数据 data:image/s3,"s3://crabby-images/75be9/75be9a44744715b4e610943e099e794220405737" alt="在这里插入图片描述" 3.引入mock,模拟数据;把json数据格式引入进来 data:image/s3,"s3://crabby-images/10719/107194003bf15c0dca90e5966d29cfac87d5406f" alt="在这里插入图片描述" 在入口文件main.js中执行 data:image/s3,"s3://crabby-images/9661e/9661e35d91c24b65ddaac820f6775a832a647843" alt="在这里插入图片描述" 4.在network中封装mock的请求 data:image/s3,"s3://crabby-images/6de5f/6de5f6ddc03c270669dbb166a9ff4782dfc55232" alt="在这里插入图片描述"
5.剩下的就和使用axios一样的步骤。
|