【VUE学习笔记】mockAxios流程:

项目场景:

需要做假数据,mockAxios


解决方案:

第一步:在src目录下新建mock文件夹

用于存放JSON格式的数据

第二步:在src目录下的api文件夹,创建mockAxios.js

用于对axios进行二次封装

//对Axios进行二次封装
import axios from "axios";
//引入进度条
import nprogress from "nprogress";
//引入进度条样式
import "nprogress/nprogress.css";
//start()开始进度条   done()结束进度条

//1:利用axios对象的方法create,去创建一个axios实例
//2:request就是axios,只不过稍微配置一下
let requests = axios.create({
  //配置对象
  //基础路径,发请求的时候,路径当中会出现/mock
  baseURL: "/mock",
  //超时时间,单位是毫秒
  timeout: 5000,
});

//请求拦截器:在发请求之前,请求拦截器可以检测到,可以在请求发出去之前做一些事情
requests.interceptors.request.use((config) => {
  //config:配置对象,对象里面有一个属性很重要,headers请求头
  //进度条开始动
  nprogress.start();
  return config;
});

//响应拦截器
requests.interceptors.response.use(
  (res) => {
    //成功的回调函数:服务器相应数据回来以后,响应拦截器可以检测到,可以做一些事情
    //进度条结束
    nprogress.done();
    return res.data;
  },
  (error) => {
    //失败的回调函数:服务器相应数据回来以后,响应拦截器可以检测到,可以做一些事情
    return Promise.reject(new Error("请求失败"));
  }
);

//对外暴露封装后的axios
export default requests;

第三步:在src目录下的api文件夹,创建index.js

//当前这个模块,对所有的接口进行统一管理
//引入二次封装的mockAxios
import mockAxios from "./mockAxios";
//获取所需的mock数据,此处演示为/banner
export const reqGetBannerList = () => mockAxios.get("/banner");

第四步:给所需组件挂载完成后的钩子函数mounted添加dispatch

也可以到第六步的时候一起写
当该数据会被父组件用于遍历生成子组件时,要写在父组件里

mounted() {
    //派发action:通知Vuex发起请求
    this.$store.dispatch("getBannerListData");
  },

第五步:在src目录下的store文件夹(仓库),创建index.js文件

写actions和mutations函数
写getters函数简化数据
请注意修改形参名字,不要照抄

//引入封装后的axios
import { reqGetBannerList } from "@/api/index";

//state
const state = {
  //state中初始化的默认空数据的数值类型要与服务器返回值的类型相同
  bannerList: [],
};

//mutations,处理数据
const mutations = {
  BANNERLIST(state, bannerList) {
    state.categoryList = bannerList;
  },
};

//actions:处理action,可以书写自己的业务逻辑  ,也可以异步提交mutation
//注意更改state的操作要交给mutations完成
const actions = {
  //通过API接口函数的调用,向服务器发请求,获取服务器端数据
  //异步获取banner的mock数据
  async getBannerListData({ commit }) {
    let result = await reqGetBannerList();
    // console.log(result);
    if (result.code === 200) {
      //提交mutation,通知更改state数据
      commit("BANNERLIST", result.data);
    }
  },
};

//getters:获取state中的数据, 相似于计算属性,用于简化仓库数据, 让组件获取仓库数据更加方便
const getters = {
  //当前的形参state是当前仓库中的,不是大仓库的state
  goodsList(state) {
    //这样写,假如没有网络导致没有数据,那么state.searchList是undefined,所以这里需要判断
    //此处a||b的意思是,如果a有值,那么就返回a,如果a没有值,那么就返回b
    return state.searchList.goodsList || [];
  },
  trademarkList(state) {
    return state.searchList.trademarkList || [];
  },
  attrsList(state) {
    return state.searchList.attrsList || [];
  },
};
	//对外暴露store类的一个实例
	export default {
	  state,
	  mutations,
	  actions,
	  getters,
	};

第六步:给所需组件引入mapState

import { mapState } from "vuex";
export default {
  name: "ListContainer",
  mounted() {
    //派发action:通知Vuex发起请求
    this.$store.dispatch("getBannerListData");
  },
  computed: {
    ...mapState({
      bannerList: (state) => state.home.bannerList,
    }),
  },
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值