黑马智数Day3

渲染基础Table列表

封装接口:

javascript 复制代码
export function getCardListAPI(params) {
  return request({
    url: '/parking/card/list',
    params
  })
}

具体实现:

javascript 复制代码
  import { getCardListAPI } from '@/apis/card'
  export default {
    data() {
      return {
        // 请求参数
        params: {
          page: 1,
          pageSize: 10
        },
        // 月卡列表
        cardList: []
      }
    },
    mounted() {
      this.getCardList()
    },
    methods: {
      async getCardList() {
        const res = await getCardListAPI(this.params)
        this.cardList = res.data.rows
      }
    }
  }
html 复制代码
  <el-table style="width: 100%" :data="cardList">
    <el-table-column type="index" label="序号" />
    <el-table-column label="车主名称" prop="personName" />
    <el-table-column label="联系方式" prop="phoneNumber" />
    <el-table-column label="车牌号码" prop="carNumber" />
    <el-table-column label="车辆品牌" prop="carBrand" />
    <el-table-column label="剩余有效天数" prop="totalEffectiveDate" />
    <el-table-column label="操作" fixed="right" width="180">
      <template #default="scope">
        <el-button size="mini" type="text">续费</el-button>
        <el-button size="mini" type="text">查看</el-button>
        <el-button size="mini" type="text">编辑</el-button>
        <el-button size="mini" type="text">删除</el-button>
      </template>
    </el-table-column>
  </el-table>

适配状态显示

javascript 复制代码
<el-table-column label="状态" prop="cardStatus" :formatter="formatStatus" />

formatStatus(row) {
  const MAP = {
    0: '可用',
    1: '已过期'
  }
  return MAP[row.cardStatus]
}

分页功能实现

  1. 页数分出来

  2. 点击每页的时候获取当前页的数据重新渲染到table上

  3. 通过实践获取到当前点击的是第几页

  4. 以当前拿到的页数作为参数去和后端要数据

  5. 把获取到的当前页的列表数据重新渲染到table组件上

搜索功能实现

收集查询字段数据

javascript 复制代码
<!-- 搜索区域 -->
<div class="search-container">
  <span class="search-label">车牌号码:</span>
  <el-input v-model="params.carNumber" clearable placeholder="请输入内容" class="search-main" />
  <span class="search-label">车主姓名:</span>
  <el-input v-model="params.personName" clearable placeholder="请输入内容" class="search-main" />
  <span class="search-label">状态:</span>
  <el-select v-model="params.cardStatus">
    <el-option
      v-for="item in cardStatusList"
      :key="item.id"
      :value="item.id"
      :label="item.name"
    />
  </el-select>
  <el-button type="primary" class="search-btn" @click="doSearch">查询</el-button>
</div

data() {
    return {
      // 请求参数
      params: {
        page: 1,
        pageSize: 5,
        carNumber: null,
        personName: null,
        cardStatus: null
      },
      // 月卡状态
      cardStatusList: [
        {
          id: null,
          name: '全部'
        },
        {
          id: 0,
          name: '可用'
        },
        {
          id: 1,
          name: '已过期'
        }
      ]
    }
  }

调用接口获取数据

javascript 复制代码
doSearch() {
  // 调用接口之前把页数参数重置为1
  this.params.page = 1
  this.getCardList()
}

<el-button type="primary" class="search-btn" @click="doSearch">查询</el-button>
相关推荐
优雅永不过时·35 分钟前
three.js 通过着色器实现热力图效果
前端·javascript·智慧城市·three.js·热力图·着色器
lizi888881 小时前
手把手教你用Python进行Web抓取(附代码)
前端·python·php
小彭努力中1 小时前
45. 圆形平面设置纹理贴图
前端·3d·webgl·贴图
i80131 小时前
基于IntraWeb的数据表格的多选实现
前端
new Vue()2 小时前
vue.js 原生js app端实现图片旋转、放大、缩小、拖拽
前端·javascript·vue.js
麒麟而非淇淋2 小时前
Vue 技术进阶 day2 数据监视的原理、其他内置指令、自定义指令、生命周期、组件化、VueComponent构造函数
前端·javascript·vue.js
战族狼魂2 小时前
基于TypeScript+React+AntDesign 的车辆车型管理页面
javascript·react.js·typescript
曹天骄2 小时前
使用 React useEffect 实现条件判断的最佳实践
前端·react.js·前端框架
想做一只快乐的修狗2 小时前
【React】react hooks的使用规则
前端·react.js·前端框架
BHDDGT2 小时前
react-问卷星项目(2)
前端·react.js·前端框架