【Vue项目心得笔记】Search模块开发(一般的四个步骤)

(1)先静态页面+静态组件

(2)发请求(API)

//获取搜索模块 地址:/api/list  请求方式:post  请求需要带参数
//当前接口,给服务器传递参数params,至少是一个空对象
export const reqGetSearchInfo =(params)=>requests({url:'/list',method:'post',data:params})

 (3)vuex三连环

import { reqGetSearchInfo } from "@/api"
//search模块的小仓库
//state:仓库存储数据的地方
const state = {
    searchList:{}
}
//mutations:修改state的唯一手段
const mutations = {
    GETSEARCHLIST(state,searchList){
        state.searchList = searchList
    }
}
//actions:处理action,可以书写自己的业务逻辑,也可处理异步
const actions = {
    //获取search模块数据
    async getSearchList({commit},params={}){
        //当前这个reqgetsearchinfo这个函数在调用服务器数据的时候,至少要传递一个参数
        //params:是当前用户派发action的时候,第二个参数传递过来的 至少是一个空对象
        let result = await reqGetSearchInfo(params)
        if(result.code==200){
            commit("GETSEARCHLIST",result.data)
        }
    }
}
//getters:理解为计算属性,用于简化仓库数据,让组件获取仓库的数据更加方便
const getters = {}


export default {
    state,
    mutations,
    actions,
    getters
}

测试接口的数据格式: 在组件里面

 (4)组件获取仓库数据,动态展示数据

监听路由的变化,再次发送请求获取数据

    watch:{
      //监听路由的信息是否发生变化,如果发生变化,再次发送请求
      $route(newValue,oldValue){
        //再次发送请求之前整理带给服务器的数据
        Object.assign(this.searchParams,this.$route.query,this.$route.params)
        //再次发送ajax请求
        this.getData()
        //每次请求完毕,应该把相应的123级分类的id置空,让他接收新的id
        this.searchParams.category1Id=''
        this.searchParams.category2Id=''
        this.searchParams.category3Id=''
      }
    }

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

翘阳啦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值