• 对elementui中分页组件进行二次封装


    为什么二次封装

    一般在后台管理项目当中,页面功能涉及到的数据展示的地方会比较多,而其中却少不了表格,分页以及条件检索。如果代码是 copy 来又 copy 去,岂不是很没有技术含量。

    而且每个项目的UI设计师,都有自己的想法。

    按照我们的直男思想,UI组件的配色啊风格啊那不挺好的嘛~ 你不用设计,我不用改样式,香香~

    不过我们也要尊重人家的劳动成果,当设计风格和 ui 框架提供的样式风格或者布局出现了差异,还是要手动的来实现一下

    另外一点,就是如果需求改一点东西,假如你的分页真的是 copy 来 copy 去的,那恭喜你,有的改了。

    基于以上的种种原因吧,elementui 的分页组件的二次封装就应时而生了。

    子组件代码

    在分页子组件中,我们只需要关注三个地方

    • 当前页是第几页,
    • 共有多少页,
    • 每页显示多少条数据

    很显然,默认的当前页肯定是第一页,

    每页显示多少条数据,需要用户自己来定义,用户没有选择的话我们给一个默认值

    而共有多少页,需要看后台返回的数据总数量,除以每页显示的数据量 简单来说,就是 Math.ceil(count / pageSize)

    根据 elementui 的分页,我们可以这样定义自己的分页组件代码

    1. // components/page/index.vue

    这里面通过内置组件 slot 来定义一些个人风格的展示效果,然后我们在 script 中定义子组件需要的参数,这里需要两个参数

    1. 总的数据量
    2. 每页显示的条目数量
    1. props: {
    2. count: {
    3. type: Number,
    4. default: 0
    5. },
    6. pageSize: {
    7. type: Number,
    8. default: 10
    9. }
    10. },

    其中的 count 来源于接口API返回的总数据量,而 pageSize 就是我定义的每页显示的数据量,用户可以自己根据需要来设置,默认是显示10条数据

    然后利用计算属性,来计算共有多少页

    1. computed: {
    2. pages() {
    3. return Math.ceil(this.count / this.pageSize)
    4. }
    5. },

    同时,我们要需定义当前的默认的页码

    1. data() {
    2. return {
    3. currentPage: 1 // 默认当前页显示第一页
    4. }
    5. },

    最后来定义翻页事件,这个事件在用户点击具体的页码,或者上一页、下一页的按钮来触发

    因为我们在绑定currentPage 用了 .sync 修饰符,所以这个属性会自动接收更新后的值,就不需要我们再做什么赋值操作了

    在事件内部,通过$emit这个方法,我们将当前跳转的页码传递给父组件用于获取更新后的数据

    1. methods: {
    2. handleCurrentChange(page) { // 点击页码事件,通知父组件
    3. this.$emit('pageEvent', this.currentPage)
    4. }
    5. }

    这样,一个子组件就完成了。

    下面看看如何在父组件中使用。

    在父组件中的使用

    1. <script>
    2. // 首先,我们先引入这个子组件,并在父组件中注册
    3. import myPagination from '@/components/page/index'
    4. import { getLog } from '@/api/user'
    5. export default {
    6. // 然后在父组件中注册子组件
    7. components: { myPagination },
    8. data(){
    9. return {
    10. loading: true,
    11. page: 1,
    12. data: [],
    13. count: 0
    14. }
    15. },
    16. methods: {
    17. fetchData(currentpage) {
    18. if (typeof currentpage === 'number') { // 切换页码
    19. this.page = currentpage
    20. } else { // 在输入检索条件进行查询的时候,将当前页设置为 1
    21. this.page = 1
    22. }
    23. const { page, searchKey } = this
    24. getLog({ page, searchKey }).then(r => {
    25. this.data = r.results
    26. this.count = r.count
    27. }).catch().finally(this.loading = false)
    28. }
    29. }
    30. }
    31. script>

    在多个父组件中,我们都可以以同样的方式引入注册并使用。

    如果后面有任何的需求更改,我们直接更改 /components/page/index.vue 就可以了,而不必在每个使用的地方都修改一次。


    原文链接:基于 elementui 分页进行二次封装 - 掘金 (juejin.cn)

  • 相关阅读:
    Bypass Windows Defender Dump Lsass(手法拙劣)
    2022CCPC预选赛C Guess(博弈)
    题型分类汇总
    深度学习的未来:继续焕发活力还是逐渐落寞?
    RabbitMQ学习笔记
    git stash的使用方法
    无涯教程-JavaScript - TRANSPOSE函数
    聊聊Go语言的向前兼容性和toolchain规则
    web前端翻页:技术探秘与未来趋势
    MYSQL入门与进阶(五)
  • 原文地址:https://blog.csdn.net/qq_45530512/article/details/126353342