码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • antd-design-vue Table组件全局配置(分页器...)


    描述:该框架许多默认配置好像还不支持,一般都是挨个使用挨个配置。我的项目中也遇到了类似的情况,但是当需求发生变化时,代码所有的组件使用则都需要修改,这种方式真的很不礼貌。

    《我为了一口醋包了顿饺子》

    需求是将系统所有的分页条数修改成自定条数。如下,就需要挨个修改定义.......

    思考再三,决定还是封装一个组件

    1. <template>
    2. <Table v-bind="$attrs" v-on="$listeners" :pagination="props.pagination">
    3. <template v-for="slotName in slotNames" #[slotName]="body">
    4. <template v-if="slots[slotName]">
    5. <slot :name="slotName" v-bind="body"/>
    6. template>
    7. template>
    8. Table>
    9. template>
    10. <script lang="ts">
    11. import {defineComponent} from 'vue';
    12. // 单独引入(否则OOM!)
    13. import {Table} from 'ant-design-vue';
    14. export default defineComponent({
    15. inheritAttrs: false,
    16. props: {
    17. pagination: {type: Object, default: false},// 不需要传递的属性
    18. },
    19. components: {
    20. Table
    21. },
    22. setup(props, {slots}) {
    23. // 获取所有插槽
    24. const slotNames = Object.keys(slots);
    25. // 自定义分页器大小(为了这口醋,包了顿饺子)
    26. if (props.pagination) props.pagination.pageSizeOptions = ['5', '10', '20', '50'];
    27. return {
    28. slots,
    29. props,
    30. slotNames
    31. }
    32. },
    33. })
    34. script>

    还没完,你代码已经引入很多的a-table的情况,就需要在main.js全局注册该组件:

    1. import {createApp} from 'vue';
    2. import Antd from 'ant-design-vue';
    3. import AntTable from "@/components/AntTable.vue";
    4. const app = createApp(App);
    5. app.use(Antd);
    6. app.component('a-table', AntTable);// 覆盖组件
    7. app.mount('#app');

    至此,无缝替换......[撒花],一键二连唔~

    注:该框架其它组件也可以使用类似方法。

  • 相关阅读:
    【高效开发工具系列】PlantUML入门使用
    如何提高小红书笔记的互动率
    Agile.NET Code Protection保护功能
    大型电商系统的订单设计
    智慧公厕自动化保洁系统,让公共厕所实现7*24 持续整洁
    使用WSL2技术在Windows子系统中安装Ubuntu并安装docker及docker-compose(图文详细教程)
    智慧社区搭载联网智能门锁,出行体验不一般!
    论文解析——一种多核处理器直连接口QoS的设计与验证
    Python网络爬虫介绍
    MySql数据库-02MySQL环境搭建
  • 原文地址:https://blog.csdn.net/yyd6976/article/details/133134651
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号