ProTable 专业表格

专业表格在一般表格的基础上进行了封装

  • 提供了 api 属性, 方便直接传 api 进行数据请求
  • 提供列的配置
  • 提供了装饰器模式

一个使用的例子

WARNING

本例子中 table 的 api 属性需要你全局设置 table 的请求方法, 就像以下那样在你的入口文件中指定, 设置一次即可.

// 你的入口文件 main.ts
import { useConfig } from 'element-ultra'

// 该函数就是将参数别名成你的后端所需要的查询数据格式, 并且返回一个组件需要的格式的组件
const request: ProTableRequestMethod = ({ api, query }) => {
  //  在控制台查看参数
  console.log('api: ', api)
  console.log('query', query)

  return new Promise((rs, rj) => {
    setTimeout(() => {
      const data = Array.from({ length: 20 }).map((_, i) => ({
        name: '张' + i,
        age: 10 + i,
      }))
      rs({
        data,
        total: data.length, // 在分页时total必须返回
      })
    }, 600)
  })
}
const [, setConfigStore]  = useConfig()
setConfigStore({
  // 表格分页的默认分页size
  proTableDefaultSize: 60,
  // 请求方法
  proTableRequestMethod: request,
})

表格装饰器

pro-table的装饰器通俗点说就是动态改变原有组件功能的一种模式, 你不需要去修改组件, 就能够对组件产生影响.

目前支持的有

  • tools装饰器
import { useConfig } from 'element-ultra'
const [, setConfigStore] = useConfig()

const MyComponent = defineComponent({
  setup(props) {
    return () => {
      return (
        <div>
          我的组件
        </div>
      )
    }
  }
})

// 使用全局配置函数来装饰
setConfigStore({
  proTableExtraTools: [
    MyComponent
  ]
})

// 一旦在入口文件设置了全局插入的组件
// 将会在全局生命周期内生效

ProTable 属性



type PropTableProps = {
  /** 列配置 */
  columns: ProTableColumn[];
  /** 展现分页 */
  pagination?: boolean;
  /** 数据请求接口, 如果传了data属性, 该属性将失效 */
  api?: string;
  /** 数据 */
  data?: any[];
  /** 在左侧展现索引 */
  showIndex?: boolean;
  /** 显示复选框与selectable属性互斥, 只有一个生效 */
  checkable?: boolean | ((row: any, index: number) => boolean);
  /** 显示单选框与checkable属性互斥, 只有一个生效 */
  selectable?: boolean | ((row: any, index: number) => boolean);
  /** 检索对象, 传入table来让table自动帮你筛选数据 */
  query?: Record<string, any>;
  /** 表格高度, 一旦指定表头就会固定了 */
  height?: number | string;
  /** 是否显示工具栏, 默认为true */
  showTools?: boolean;
  /** 是否默认展开全部 */
  defaultExpandAll?: boolean;
  /** 单元格最小宽度, 默认 100 */
  cellMinWidth?: number;
}

ProTableColumn 属性

interface ProTableColumn {
  /** 列的默认宽度 */
  width?: number
  /** 列的最低宽度, 如果同时设置了width, 则以width为优先 */
  minWidth?: number;
  /** 列的名称, 在表头中显示 */
  name: string | (() => VNode)
  /** 从值中取的字段, 支持链式 */
  key: string
  /** 是否支持排序 */
  sort?: boolean
  /** 自定义渲染 */
  render?: (row: any, index: number, val: string) => any
  /** 对齐方式 */
  align?: 'left' | 'center' | 'right'
  /** 是否固定 */
  fixed?: 'left' | 'right'
  /** 子列 */
  children?: ProTableColumn[]
}

ProTable 插槽

名称说明
row-expand展开行内容
[column.slot]在列中自定义的插槽名称
tools在列中自定义的插槽名称, 请查看
searcher搜索控件插槽, 请查看