优雅的使用 element-ui 中的 table 组件之升级版

简介: 优雅的使用 element-ui 中的 table 组件之升级版

优雅的使用 element-ui 中的 table 组件之升级版


原文在这里,优雅的使用 element-ui 中的 table 组件, 作者写的很棒,我在项目里也广泛使用,很好用,使用过程中,因为需要其他的功能,我在作者原有的基础上,升级了原组件,主要增加了以下:

  • slot-scope统一替换成v-slot
  • 自定义排序
  • 可勾选
  • 加载状态

EnhancedTable的代码

点击预览

github地址

先贴上源码,我喜欢用pug,其实就是去掉成对的标签,属性在括号里,通过缩进表达嵌套关系。让项目能用pug的话,npm install pug pug-cli pug-plain-loader -D即可。

<template lang="pug">
el-table(:data="tableData" v-loading="isLoad" stripe v-bind="tableConfig" @sort-change="changeSort" @selection-change="changeSelectRows")
  template(v-for="colConfig in colConfigs")
    //- 循环每一项 有slot的单独渲染
    slot(v-if="colConfig.slot" :name="colConfig.slot" :col-config="colConfig")
    //- 有component的单独渲染
    component(v-else-if="colConfig.component" :is="colConfig.component" :col-config="colConfig")
    //- 普通项
    el-table-column(v-else v-bind="colConfig")
</template>
<script>
export default {
  name: 'enhanced-table',
  props: { colConfigs: Array, tableData: Array, tableConfig: Object, isLoad: Boolean },
  methods: {
    // 提前先定义排序事件,需要用的时候直接在父组件使用
    changeSort ({ column, prop, order }) {
      this.$emit('sort-change', column, prop, order)
    },
    // 提前先定义排序事件,需要用的时候直接在父组件使用
    changeSelectRows (val) {
      this.$emit('selection-change', val)
    }
  }
}
</script>

父组件使用EnhancedTable

综合使用的demo代码如下

<template lang="pug">
ul
  li
    h2(id="#basic") 基本表格
    enhanced-table(:tableData="tableData" :col-configs="basicTableConfigs")
  li
    h2 特殊行用slot的表格
    enhanced-table(:tableData="tableData" :col-configs="slotTableConfigs")
      template(v-slot:options="{colConfig}")
        el-table-column(v-bind="colConfig")
          template(v-slot="{row}")
            el-button(size="mini") 查看{{row.date}}
  li
    h2 特殊行用component的表格
    enhanced-table(:tableData="tableData" :col-configs="componentTableConfigs")
  li
    h2 有排序的表格
    enhanced-table(:tableData="tableData" :col-configs="sortedTableConfigs",@sort-change='changeCustomSort')
  li
    h2 可以勾选行的表格
    enhanced-table(:tableData="tableData" :col-configs="selectRowTableConfigs",@selection-change="selectDeleteRows")
  li(id="#loading")
    h2 有加载状态的表格
    enhanced-table(:is-load='isShowTableLoading' :tableData="tableData" :col-configs="selectRowTableConfigs")
</template>
<script>
// @ is an alias to /src
import EnhancedTable from '@/components/EnhancedTable.vue'
import PrefixPlusText from '@/components/PrefixPlusText.vue'
export default {
  name: 'home',
  components: {
    EnhancedTable,
    PrefixPlusText
  },
  data () {
    let basicTableConfigs = [
      { prop: 'date', label: '日期' },
      { prop: 'name', label: '姓名' },
      { prop: 'address', label: '地址' },
      { prop: 'trend', label: '趋势' }
    ]
    let slotTableConfigs = [
      { prop: 'date', label: '日期' },
      { prop: 'name', label: '姓名' },
      { prop: 'address', label: '地址' },
      { prop: 'trend', label: '趋势' },
      { slot: 'options', label: 'slot的操作', message: 'message' }
    ]
    let componentTableConfigs = [
      { prop: 'date', label: '日期' },
      { prop: 'name', label: '姓名' },
      { prop: 'address', label: '地址' },
      { component: PrefixPlusText, prop: 'change', label: 'component的变化' },
      { prop: 'trend', label: '趋势' }
    ]
    let sortedTableConfigs = [
      { prop: 'date', label: '有排序的日期,不是自定义的不需要加事件', sortable: true },
      { prop: 'name', label: '自定义排序的姓名,需要加事件', sortable: 'custom' },
      { prop: 'address', label: '地址' },
      { prop: 'trend', label: '趋势' }
    ]
    let selectRowTableConfigs = [
      { prop: '随便', type: 'selection', label: '日期' },
      { prop: 'date', label: '日期' },
      { prop: 'name', label: '姓名' },
      { prop: 'address', label: '地址' },
      { prop: 'trend', label: '趋势' }
    ]
    let loadingTableConfigs = [
      { prop: 'date', label: '日期' },
      { prop: 'name', label: '姓名' },
      { prop: 'address', label: '地址' },
      { prop: 'trend', label: '趋势' }
    ]
    return {
      basicTableConfigs,
      slotTableConfigs,
      componentTableConfigs,
      sortedTableConfigs,
      // 下面rowsToDelete在勾选事件的时候能是数组,每项就是row
      selectRowTableConfigs,
      rowsToDelete: [],
      // 下面的isShowTableLoading就是加载的flag
      loadingTableConfigs,
      isShowTableLoading: true,
      tableData: [{
        id: '1',
        date: '2016-05-02',
        name: '王小虎',
        address: '上海市普陀区金沙江路 1518 弄',
        change: '12%',
        trend: '10%'
      }]
    }
  },
  mounted () {
    setTimeout(() => {
      this.isShowTableLoading = false
    }, 1000)
  },
  methods: {
    changeCustomSort (column, prop, order) {
      console.log(arguments)
      let isAsc
      order === null && (isAsc = '')
      order === 'ascending' && (isAsc = true)
      order === 'descending' && (isAsc = false)
      this.sortBy = prop
      this.isAsc = isAsc
    },
    selectDeleteRows (val) {
      console.log(arguments)
      this.rowsToDelete = val
    }
  }
}
</script>


目录
相关文章
|
5月前
|
开发者 容器
44.[HarmonyOS NEXT RelativeContainer案例一] 掌握组件锚点布局:打造灵活精准的UI定位系统
在HarmonyOS NEXT的UI开发中,精确控制组件位置是构建复杂界面的关键。RelativeContainer作为一种强大的布局容器,通过锚点系统提供了精确定位能力,使开发者能够创建出灵活且精准的UI布局。本教程将详细讲解如何使用RelativeContainer的锚点布局功能,帮助你掌握这一核心技术。
196 4
|
5月前
|
设计模式 缓存 容器
06.HarmonyOS Next UI进阶:Text组件与视觉样式完全指南
在HarmonyOS Next应用开发中,Text组件是最基础也是最常用的UI元素之一。它不仅用于显示文本内容,还可以通过丰富的样式属性实现各种视觉效果。掌握Text组件的样式设置,是构建精美UI界面的基础技能。
287 1
|
2月前
|
Linux Go iOS开发
IDA 9.2 发布:Golang 改进、新 UI 组件、类型解析等
IDA Pro 9.2 (macOS, Linux, Windows) - 强大的反汇编程序、反编译器和多功能调试器
613 0
|
4月前
|
Web App开发 前端开发 JavaScript
Element UI框架中自定义input组件的placeholder样式。
确保这些样式在你的应用程序CSS文件中定义,且该文件已正确加载到项目中。通过以上方法,可以控制Element UI组件中input的placeholder样式,使其满足特定的设计要求。这些更改都是基于CSS伪元素进行的,因此并不会对DOM结构产生改变,保持了原有结构的简洁和高效。
430 12
|
9月前
|
前端开发 安全 开发工具
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
570 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
5月前
|
移动开发 开发者
仓颉开发语言入门教程:常见UI组件介绍和一些问题踩坑
仓颉开发语言即将发布一周年,虽已有知名App应用,但教程稀缺且官网文档不够完善。幽蓝君推出系列教程,从零开始系统讲解移动开发。本期介绍常用UI组件:按钮、文本、图片、输入框与搜索框的使用方法及注意事项,帮助开发者快速上手仓颉语言。
|
9月前
|
JavaScript 数据安全/隐私保护
Vue Amazing UI 组件库(Vue3+TypeScript+Vite 等最新技术栈开发)
Vue Amazing UI 是一个基于 Vue 3、TypeScript、Vite 等最新技术栈开发构建的现代化组件库,包含丰富的 UI 组件和常用工具函数,并且持续不断维护更新中。另外,组件库全量使用 TypeScript,支持自动按需引入和 Tree Shaking 等,能够显著提升开发效率,降低开发成本。
556 5
Vue Amazing UI 组件库(Vue3+TypeScript+Vite 等最新技术栈开发)
|
11月前
「Mac畅玩鸿蒙与硬件46」UI互动应用篇23 - 自定义天气预报组件
本篇将带你实现一个自定义天气预报组件。用户可以通过选择不同城市来获取相应的天气信息,页面会显示当前城市的天气图标、温度及天气描述。这一功能适合用于动态展示天气信息的小型应用。
488 38
「Mac畅玩鸿蒙与硬件46」UI互动应用篇23 - 自定义天气预报组件
|
9月前
|
人工智能 自然语言处理 前端开发
Flame:开源AI设计图转代码模型!生成React组件,精准还原UI+动态交互效果
Flame 是一款开源的多模态 AI 模型,能够将 UI 设计图转换为高质量的现代前端代码,支持 React 等主流框架,具备动态交互、组件化开发等功能,显著提升前端开发效率。
1291 1
|
8月前
|
安全 API 开发者
深入探索ArkUI中的@LocalBuilder装饰器:构建高效可维护的UI组件
在ArkUI框架中,组件化开发至关重要。@LocalBuilder作为自API version 12引入的装饰器,专注于组件内部私有构建,确保封装性与安全性。本文解析其工作原理、参数传递机制及与@Builder的区别,结合典型场景代码示例,助开发者掌握这一工具。通过状态驱动UI更新、复杂组件组合等实践,优化性能并提升代码可维护性,推动高效UI架构构建。
236 0

热门文章

最新文章