vue二次封装pagination的分页实操

项目技术栈

我这个项目使用了vite+ts+vue3,前端ui框架选择的是Naiveui ,本人感觉这个框架确实挺好看的,这次做的是一个练手的项目,所以就随便选咯。

准备二次封装分页

不多说,上代码如下:

<template>
  <div>
    <!-- 分页插件进行封装 -->
    <n-pagination
      v-model:page="currentPage"
      v-model:page-size="pageSize"
      :size="size"
      :page-sizes="[10, 20, 30, 40]"
      :show-quick-jumper="showJumper"
      :show-size-picker="showPicker"
      @update:page="handleCurrentChange"
      @update:page-size="handleSizeChange"
      :page-slot="pageSlot"
      :item-count="total"
    />
  </div>
  <!-- <div>{{ boxSize }}</div> -->
</template>

<script setup lang="ts">
import { ref, computed } from "vue";
const props = defineProps({
  size: {
    type: String,
    default() {
      return "medium";
    },
  },
  total: {
    type: Number,
    required: true,
  },
  page: {
    // 当前页码
    type: Number,
    default: 1,
  },
  limit: {
    type: Number,
    default: 10,
  },
});
const emit = defineEmits();
const currentPage = computed({
  set(val) {
    emit("update:page", val);
  },
  get() {
    return props.page;
  },
});
const pageSize = computed({
  set(val) {
    emit("update:limt", val);
  },
  get() {
    return props.limit;
  },
});
let handleCurrentChange = (page: any) => {

  emit("pagination", {
    page: page,
    limit: pageSize.value,
  });
};
let handleSizeChange = (page: any) => {
  emit("pagination", {
    currentPage: currentPage.value,
    limit: page,
  });
};
const vieWidth = ref();
vieWidth.value = document.documentElement.clientWidth || document.body.clientWidth;
let showPicker = computed(() => {
  return vieWidth.value < 992 ? false : true;
});
let showJumper = computed(() => {
  return vieWidth.value < 992 ? false : true;
});
let pageSlot = computed(() => {
  return vieWidth.value < 992 ? 5 : 9;
}); // 监听
window.onresize = () => {
  vieWidth.value = document.documentElement.clientWidth || document.body.clientWidth;
};
</script>
<style scoped></style>

项目中使用

部分代码贴图

<div class="flex items-center justify-end mt-[50px]">
              <w-pagination
                v-model:page="queryParam.pageNum"
                v-model:limit="queryParam.pageSize"
                v-show="total > 0"
                :total="total"
                @pagination="getList"
              ></w-pagination>
      </div>

注意事项

其实这个ui框架的方法和element-ui plus其实基本一模一样,所以使用elementui-plus的同学也可以直接拿过去使用,elementui-plus用法如下:

<template>
  <div >
    <el-pagination
      v-model:current-page="currentPage"
      v-model:page-size="pageSize"
      :page-sizes="pageSizes"
      :pager-count="pagerCount"
      :total="total"
      @size-change="handleSizeChange"
      @current-change="handleCurrentChange"
    />
  </div>
</template>



</script>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值