bird-grid是一个简化业务系统增删改查的全自动表格组件。组件内部处理数据加载、分页、排序、查询、新增、编辑等一系列操作。让业务表格开发变得异常简单。
- 丰富的列类型支持,包括文本、文本域、数字、bool、单选、多选、级联选择、富文本、图片/文件、日期、时间等类型。
- 新增、编辑零代码,支持自定义的编辑配置(提示、是否必填、正则验证等)。
- 查询、排序、分页零代码。每列均可查询、排序。
- 自定义按钮,默认提供查询、新增、修改、删除、刷新等操作按钮。
- 按钮级权限控制。
- 支持用户选择要显示的列。
render() {
let gridOption = {
title: "表格示例",
url: {
read: "/api/v1/table",
add: "/test/add",
edit: "/test/edit",
delete: "/test/delete"
},
checkable: true,
actions: [{ name: '外部按钮', onClick: function () { } }],
columns: [
{ title: "编号", data: "id", type: "number" },
{ title: "文本", data: "d1", type: "text", editor: {}, query: true },
{ title: "整数", data: "d2", type: "number", editor: {}, query: true },
{ title: "小数", data: "d3", type: "number", editor: { step: 0.1, precision: 2 } },
{ title: "布尔值", data: "d4", type: "switch", editor: {}, query: true },
{ title: "单选", data: "d5", type: "dropdown", editor: {}, source: { url: '/api/v1/getOptions' }},
{ title: "多选", data: "d6", type: "multi", editor: {}, source: { key: 'xx' } },
{ title: "级联选择", data: "d7", type: "cascader", editor: {}, source: { url: '/api/v1/tree' } },
{ title: "图片", data: "d8", type: "img", editor: { ap: 'hide', ep: 'hide' }, hide: true },
{ title: "多图片", data: "d9", type: "imgs", editor: { ap: 'hide', ep: 'hide' }, hide: true },
{ title: "文件", data: "d10", type: "file", editor: {} },
{ title: "多文件", data: "d11", type: "files", editor: { ap: 'hide', ep: 'hide' }, hide: true },
{ title: "时间", data: "d12", type: "datetime", editor: {}, query: true },
// { title: "富文本", data: "d13", type: "richtext", editor: {}, query: true },
{
title: "操作选项", type: "command", actions: [{
name: '行内按钮',
onClick: (data) => {
console.log(data);
}
}]
}
]
};
return <BirdGrid gridOption={gridOption} />
}
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
url | 表格相关服务api配置 | object | {} |
header | 自定义header,为null时不渲染 | ReactNode | |
footer | 自定义footer,为null时不渲染 | ReactNode | |
permission | 权限相关配置 | object/string | {} |
primaryKey | 标识列 | string | 第一列的data参数 |
columns | 表格列配置 | array | [] |
dataSource | 本地数据源,配置后url.read不生效 | array | [] |
checkable | 是否添加Checkbox选择框 | bool | false |
import | 是否添加导出按钮 | bool | false |
pageSize | 每页数据条数 | number | 15 |
pageSizeOptions | 每页数量选项数组 | array | ["10", "15", "20", "30", "50", "100"] |
sortField | 排序字段 | string | primaryKey |
sortDirection | 排序方式:asc、desc | string | 'desc' |
actions | 右上角操作按钮集合 | array | [新增] |
customRules | 外部筛选条件 | array | [] |
filterRules | 内部筛选条件 | array | [] |
formWidth | 默认弹出框的宽度 | number | 520 |
queryText | 查询按钮文字 | text | '查询' |
autoQuery | 是否根据url自动查询 | bool | true |
afterQuery | 查询结束后执行事件 | function | (result,filters)=>{} |
afterSave | 表单保存后执行事件 | function | ()=>{} |
colorRender | 自定义行的背景色 | function | data=>{} |
showActionCount | 顶部按钮数量,超过则收起 | number | 5 |
showRowActionCount | 行内按钮数量,超过则收起 | number | 3 |
设置本地dataSource后,url.read与autoQuery属性不生效,相关的查询也不能生效。
外部筛选条件与内部筛选条件的区别:
- 外部筛选条件是隐式查询,默认的新增、编辑会携带该参数。
- 内部筛选条件是显示查询,作用在左上角的查询区域。
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
read | 数据读取url | string | '' |
add | 数据新增url | string | '' |
edit | 数据编辑url | string | '' |
delete | 数据删除url | string | '' |
注:所有接口均使用POST提交,add/edit/delete配置均选填,不配置则不显示相关的操作按钮。
表格请求json格式:
{
"filters": [
{
"field": "string",
"operate": "string",
"value": "string"
}
],
"sumFields":["field"],
"pageIndex": 0,
"pageSize": 0,
"sortDirection": 0,
"sortField": "string"
}
接口返回json格式:
{
"items": [],
"sum":{
"field":0
},
"totalCount": "10"
}
items中对象的字段对应表格中的列。
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
add | 新增权限名称 | string | '' |
edit | 编辑权限名称 | string | '' |
delete | 删除权限名称 | string | '' |
add/edit/delete各自对应新增/编辑/删除的权限名称,不配置则表示不验证对应的权限。 permission支持字符串格式,表格初始化时会自动为其添加:add/:edit/:delete权限名。
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
title | 列名称 | string | |
data | 对应数据的字段名 | string | |
type | 列类型。text、textarea、number、money、switch、dropdown、multi、cascader、richtext、img(s)、file(s)、date、datetime、hide、command | string | |
align | 对齐方式。left、center、right,money类型默认right | string | left |
sum | 是否合计总数 | bool | false |
query | 列是否可查询 | bool | false |
sortDisable | 列是否禁止排序 | bool | false |
hide | 支持三种层级的列隐藏:no、user、dev | bool/string | 'no' |
render | 列渲染方法 | function(v,d) | |
source | 当列类型为dropdown(单选)或multi(多选)或cascader(级联选择)时的数据源 | object | |
actions | 当列类型为command时的操作按钮数组 | array | [编辑,删除] |
editor | 列的编辑设置 | object | null |
maxLength | 类型为text、textarea、richtext时最大显示长度 | number | 30 |
colSpan | 指定列宽,默认为1,设为0后,列头不显示 | number | 1 |
说明: |
- render(v,d){}方法第一个参数表示当前行当前列的数据,第二个参数表示整行的数据。
- hide层级为no、user的列,用户可选择显示或隐藏
- scource:{data:[],url:'',key:''}。当类型为
dropdown
或multi
时,其中data、url、key分别对应bird-selector
中的data、url、dicKey。当类型为cascader
时,data、url分别对应bird-cascader
中的data、url。
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
ep | 编辑模式。default、hide、disabled | string | default |
ap | 新增模式。default、hide、disabled | string | default |
tips | 提示信息 | string | '' |
isRequired | 是否必填 | bool | false |
validateRegular | 验证的正则表达式 | string | |
step | number类型下的步长 | number | 1 |
precision | number类型的精度(小数的位数) | number | 0 |
innerProps | 对应antd组件的props | object | {} |
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
name | 按钮名称 | string | |
icon | 按钮图标,只对右上角按钮有效 | string | |
onClick | 点击事件 | function(data){} | (data)=>{} |
nameFormat | 按钮名称渲染方法,根据行数据渲染不同的按钮名 | function(data){} | |
hideFunc | 根据行数据判断按钮是否显示方法 | function(data){} | |
permissionName | 所需权限名 | string/array | |
confirm | 操作是否需要确认 | bool | false |
color | 按钮颜色 | string | |
render | 自定义按钮渲染方法 | data=>element |
说明:
- 本表格所有方法接收的data为行数据(右上角按钮的onClick事件除外);
- nameFormat,只对行内action有效,优先级高于name;
- hideFunc,只对行内action有效,存在且hideFunc(data)为true时,该按钮隐藏;
- permissionName实现按钮级权限控制;
- onClick。右上角按钮:data表示表格选中的值;行内按钮:data表示行数据;
- render。自定义渲染方法,name、nameFormat、onClick不再生效;
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
field | 列字段名称 | string | |
value | 值 | string |
说明: customRules是在表格初始化之前为表格添加自定义查询条件,可用于url上不同参数对于表格数据的控制。