灏天阁

vue3.2/Vite/Ts40: 品牌管理分页数据展示

· Yin灏

目录结构

└─src
    └─views
        └─product
            └─trademark
                └─index.vue

处理分页功能

src/views/product/trademark/index.vue

<template>
  <el-card>
    <!-- ... -->
    <el-pagination
      v-model:current-page="pageNo"
      v-model:page-size="limit"
      :page-sizes="[3,5,7,9]"
      :background="true"
      layout="prev,pager,next,jumper,->,sizes,total"
      :total="total"
      @current-change="getHasTrademark"
      @size-change="sizeChange"
    ></el-pagination>
  </el-card>
</template>
<script setup lang="ts">
  import { ref, onMounted } from "vue";
  import type {
    Records,
    TradeMarkResponseData,
  } from "@/api/product/trademark/type";
  // 引入接口
  import { reqHasTrademark } from "@/api/product/trademark";
  let pageNo = ref<number>(1);
  let limit = ref<number>(3);
  let total = ref<number>(0);
  let trademarkArr = ref<Records>([]);
  // 获取品牌数据
  const getHasTrademark = async (page = 1) => {
    pageNo.value = page;
    const result: TradeMarkResponseData = await reqHasTrademark(
      pageNo.value,
      limit.value
    );
    if (result.code === 200) {
      total.value = result.data.total;
      trademarkArr.value = result.data.records;
    }
  };
  onMounted(() => {
    getHasTrademark();
  });
  const sizeChange = () => {
    getHasTrademark();
  };
</script>

- Book Lists -