Vue3手写分页在分页的基础上用到Pagination 分页组件

简介: Vue3手写分页在分页的基础上用到Pagination 分页组件

    近期有个项目要用到分页组件,但是内容不是表格,所以自己就研究了一下在Pagination 分页组件的基础上手写了分页

效果图:

原理跟 Pagination 分页组件使用差不多把对应的参数传入到相应的地方就可以。

不同之处切换对应的页数需要自己去手写一个函数然后再去调用它。

一、先声明几个变量用来定义第几页,每页多少条,总页数。

二、然后封装一个函数方便以后调用

字母 a 代表第一页

字母 b 代表每页多少条数据

三、 然后就使用到Pagination 分页来控制上一页和下一页

四、然后在 current-change事件去调用哪个函数就可以了

current-change current-page 改变时触发

在这个地方要注意一点就是每次调用前要给数据清空一下,不然会前一条数据还在后一条数在它下面。

  // 分页
  const value = ref('');
  const handleCurrentChange = (val) => {
    tableArr.value = [];
    pageNum.value = val;
    amount(pageNum.value, selecctNum.value);
  };

下面是整个代码:

<template>  
  <div class="content">
    <div class="box" v-for="(item, index) in tableArr" :key="item.id">
      <div class="under2" v-if="showCss[index]"></div>
      <div class="content_box">
        <p class="xxgy">学员感言</p>
        <p class="say">明月几时有</p>
        <div class="for_btn">
          <img src="../../assets/student_img/a1.png" alt="" />
        </div>
        <div class="students">
          <div class="students_box_mame">
            <div class="name"> 姓名: </div>
            <div class="names">{{ item.name }}</div>
          </div>
          <div class="students_box_mame">
            <div class="name"> 薪资: </div>
            <div class="names">{{ item.pay }}</div>
          </div>
          <div class="entry">
            <div class="name">入职:</div>
            <div class="names">{{ item.company }}</div>
          </div>
        </div>
      </div>
    </div>
  </div>
 <div class="pages">
    <el-pagination
      :current-page="pageNum"
      small
      background
      layout="prev, pager, next,jumper"
      :total="totalNum"
      class="mt-4"
      :page-size="selecctNum"
      @current-change="handleCurrentChange"
    />
  </div>
</template>
<script setup>
  import { ref, reactive, onMounted } from 'vue';
  // 分页
  const value = ref('');
  const handleCurrentChange = (val) => {
    tableArr.value = [];
    pageNum.value = val;
    amount(pageNum.value, selecctNum.value);
  };
let list_content = [
    {
      id: 1,
      name: '测试1',
      pay: '13k',
      company: '腾讯有限公司',
    },
    {
      id: 2,
      name: '测试2',
      pay: '15k',
      company: '支付宝有限公司',
    },
    {
      id: 3,
      name: '测试3',
      pay: '14k',
      company: '上海科技有限公司',
    },
    {
      id: 4,
      name: '测试4',
      pay: '13k',
      company: '江苏科技有限公司',
    },
    {
      id: 5,
      name: '测试5',
      pay: '13k',
      company: '天津有限公司',
    },
    {
      id: 6,
      name: '测试6',
      pay: '12k',
      company: '北京有限公司',
    },
    {
      id: 7,
      name: '测试7',
      pay: '16k',
      company: '深圳有限公司',
    },
    {
      id: 8,
      name: '测试8',
      pay: '16k',
      company: '深圳有限公司',
    },
    {
      id: 9,
      name: '测试9',
      pay: '16k',
      company: '深圳有限公司',
    },
    {
      id: 10,
      name: '测试10',
      pay: '16k',
      company: '深圳有限公司',
    },
    {
      id: 11,
      name: '测试11',
      pay: '16k',
      company: '深圳有限公司',
    },
    {
      id: 12,
      name: '测试12',
      pay: '16k',
      company: '深圳有限公司',
    },
    {
      id: 13,
      name: '测试13',
      pay: '16k',
      company: '深圳有限公司',
    },
    {
      id: 14,
      name: '测试14',
      pay: '16k',
      company: '深圳有限公司',
    },
    {
      id: 15,
      name: '测试15',
      pay: '16k',
      company: '深圳有限公司',
    },
    {
      id: 16,
      name: '测试16',
      pay: '16k',
      company: '深圳有限公司',
    },
    {
      id: 17,
      name: '测试17',
      pay: '16k',
      company: '深圳有限公司',
    },
    {
      id: 18,
      name: '测试18',
      pay: '16k',
      company: '深圳有限公司',
    },
    {
      id: 19,
      name: '测试19',
      pay: '16k',
      company: '深圳有限公司',
    },
    {
      id: 20,
      name: '测试20',
      pay: '16k',
      company: '深圳有限公司',
    },
  ];
  const tableArr = ref([]);
  // 第一页
  const pageNum = ref(1);
  // 每页多少条
  const selecctNum = ref(10);
  // 总页数
  const totalNum = list_content.length;
  // 分页处理事件
  const amount = (a, b) => {
    tableArr.value = [];
    let c = (a - 1) * b;
    if (list_content.length < a * b) {
      for (let i = c; i < list_content.length; i++) {
        tableArr.value.push(list_content[i]);
      }
    } else {
      if (a * b > list_content.length) {
        for (let i = c; i < list_content.length; i++) {
          tableArr.value.push(list_content[i]);
        }
      } else {
        for (let i = c; i < a * b; i++) {
          tableArr.value.push(list_content[i]);
        }
      }
    }
  };
  amount(pageNum.value, selecctNum.value);
</script>
相关文章
|
4天前
|
前端开发 JavaScript API
基于Vue3+Hooks实现4位随机数和60秒倒计时
本文介绍了如何在Vue3中使用Hooks API来实现生成4位随机数和执行60秒倒计时的功能,并提供了详细的代码示例和运行效果展示。
21 1
基于Vue3+Hooks实现4位随机数和60秒倒计时
|
4天前
|
数据可视化 JavaScript
Vue3项目使用G6可视化组件实现一个树形机构图
在Vue 3项目中使用G6可视化组件库实现树形机构图的构建和展示。
30 1
Vue3项目使用G6可视化组件实现一个树形机构图
|
3天前
|
JavaScript 算法 API
Vue 3有哪些新特性
【8月更文挑战第16天】Vue 3有哪些新特性
15 1
|
3天前
|
JavaScript
在Vue中使用Swiper轮播图、同时解决点击轮播图左右切换按钮不生效的问题、同时将轮播图抽离出为一个公共组件
这篇文章介绍了在Vue中如何使用Swiper插件创建轮播图,解决Swiper左右切换按钮不生效的问题,并展示了如何将Swiper轮播图抽离成一个可复用的公共组件,同时提供了详细的安装、配置和优化建议。
在Vue中使用Swiper轮播图、同时解决点击轮播图左右切换按钮不生效的问题、同时将轮播图抽离出为一个公共组件
|
4天前
|
JavaScript UED
如何在Vue3项目中使用防抖节流技巧
在Vue 3项目中使用防抖和节流技巧以优化组件性能,包括使用`lodash`库和自定义实现这两种方法。
7 0
如何在Vue3项目中使用防抖节流技巧
|
3天前
|
JavaScript
创建 Vue3 项目
创建 Vue3 项目
9 0
|
4天前
|
JavaScript
在Vue3+ElementPlus项目中使用具有懒加载的el-tree树形控件
在Vue 3和Element Plus项目中实现具有懒加载功能的el-tree树形控件,以优化大数据量时的页面性能。
6 0
|
3天前
|
JavaScript
Vue中如何设置在执行删除等危险操作时给用户提示(二次确认后执行对应的操作)
这篇文章介绍了在Vue项目中如何实现执行删除等危险操作时的二次确认机制,使用Element UI的`el-popconfirm`组件来弹出确认框,确保用户在二次确认后才会执行删除操作。
Vue中如何设置在执行删除等危险操作时给用户提示(二次确认后执行对应的操作)
|
3天前
|
JavaScript
如何创建一个Vue项目(手把手教你)
这篇文章是一篇手把手教读者如何创建Vue项目的教程,包括使用管理员身份打开命令行窗口、找到存放项目的位置、通过vue-cli初始化项目、填写项目信息、进入项目目录、启动项目等步骤,并提供了一些常见第三方库的引入方法。
如何创建一个Vue项目(手把手教你)
|
3天前
|
前端开发
StringBoot+Vue实现游客或用户未登录系统前、可以浏览商品等信息、但是不能购买商品或者加入购物车等操作。登录系统显示用户的登录名(源码+讲解)
这篇文章介绍了使用StringBoot+Vue实现用户登录状态判断的方法,包括前端加载用户信息和后端设置session的源码示例。