usePagination.ts 940 B

12345678910111213141516171819202122232425262728293031
  1. import type { Ref } from 'vue';
  2. import { ref, unref, computed } from 'vue';
  3. function pagination<T = any>(list: T[], pageNo: number, pageSize: number): T[] {
  4. const offset = (pageNo - 1) * Number(pageSize);
  5. const ret = offset + Number(pageSize) >= list.length ? list.slice(offset, list.length) : list.slice(offset, offset + Number(pageSize));
  6. return ret;
  7. }
  8. export function usePagination<T = any>(list: Ref<T[]>, pageSize: number) {
  9. const currentPage = ref(1);
  10. const pageSizeRef = ref(pageSize);
  11. const getPaginationList = computed(() => {
  12. return pagination(unref(list), unref(currentPage), unref(pageSizeRef));
  13. });
  14. const getTotal = computed(() => {
  15. return unref(list).length;
  16. });
  17. function setCurrentPage(page: number) {
  18. currentPage.value = page;
  19. }
  20. function setPageSize(pageSize: number) {
  21. pageSizeRef.value = pageSize;
  22. }
  23. return { setCurrentPage, getTotal, setPageSize, getPaginationList };
  24. }