feat: 调整分页样式,增加获取选中行方法

This commit is contained in:
xingyu 2023-01-17 11:17:09 +08:00
parent 1fd9056454
commit 28ea779f83
4 changed files with 62 additions and 12 deletions

View File

@ -229,19 +229,19 @@ const getPageConfig = (options: XTableProps) => {
if (pagination != false) { if (pagination != false) {
options.pagerConfig = { options.pagerConfig = {
border: false, // border: false, //
background: true, // background: false, //
perfect: false, // perfect: false, //
pageSize: 10, // pageSize: 10, //
pagerCount: 7, // pagerCount: 7, //
autoHidden: false, // autoHidden: false, //
pageSizes: [5, 10, 20, 30, 50, 100], // pageSizes: [5, 10, 20, 30, 50, 100], //
layouts: [ layouts: [
'Sizes',
'PrevJump', 'PrevJump',
'PrevPage', 'PrevPage',
'JumpNumber', 'Number',
'NextPage', 'NextPage',
'NextJump', 'NextJump',
'Sizes',
'FullJump', 'FullJump',
'Total' 'Total'
] ]
@ -324,12 +324,47 @@ const getSearchData = () => {
return queryParams return queryParams
} }
//
const getCurrentColumn = () => {
const g = unref(xGrid)
if (!g) {
return
}
return g.getCurrentColumn()
}
// redio
const getRadioRecord = () => {
const g = unref(xGrid)
if (!g) {
return
}
return g.getRadioRecord(false)
}
// checkbox
const getCheckboxRecords = () => {
const g = unref(xGrid)
if (!g) {
return
}
return g.getCheckboxRecords(false)
}
const setProps = (prop: Partial<XTableProps>) => { const setProps = (prop: Partial<XTableProps>) => {
innerProps.value = { ...unref(innerProps), ...prop } innerProps.value = { ...unref(innerProps), ...prop }
} }
defineExpose({ reload, Ref: xGrid, getSearchData, deleteData, exportList }) defineExpose({ reload, Ref: xGrid, getSearchData, deleteData, exportList })
emit('register', { reload, getSearchData, setProps, deleteData, exportList }) emit('register', {
reload,
getSearchData,
setProps,
deleteData,
exportList,
getCurrentColumn,
getRadioRecord,
getCheckboxRecords
})
</script> </script>
<style lang="scss"> <style lang="scss">
@import './style/index.scss'; @import './style/index.scss';

View File

@ -18,6 +18,7 @@ export type VxeCrudSchema = {
primaryKey?: string // 主键ID primaryKey?: string // 主键ID
primaryTitle?: string // 主键标题 默认为序号 primaryTitle?: string // 主键标题 默认为序号
primaryType?: VxeColumnPropTypes.Type | 'id' // 还支持 "id" | "seq" | "radio" | "checkbox" | "expand" | "html" | null primaryType?: VxeColumnPropTypes.Type | 'id' // 还支持 "id" | "seq" | "radio" | "checkbox" | "expand" | "html" | null
firstColumn?: VxeColumnPropTypes.Type // 第一列显示类型
action?: boolean // 是否开启表格内右侧操作栏插槽 action?: boolean // 是否开启表格内右侧操作栏插槽
actionTitle?: string // 操作栏标题 默认为操作 actionTitle?: string // 操作栏标题 默认为操作
actionWidth?: string // 操作栏插槽宽度,一般2个字带图标 text 类型按钮 50-70 actionWidth?: string // 操作栏插槽宽度,一般2个字带图标 text 类型按钮 50-70
@ -184,6 +185,14 @@ const filterSearchSchema = (crudSchema: VxeCrudSchema): VxeFormItemProps[] => {
const filterTableSchema = (crudSchema: VxeCrudSchema): VxeGridPropTypes.Columns => { const filterTableSchema = (crudSchema: VxeCrudSchema): VxeGridPropTypes.Columns => {
const { t } = useI18n() const { t } = useI18n()
const tableSchema: VxeGridPropTypes.Columns = [] const tableSchema: VxeGridPropTypes.Columns = []
// 第一列
if (crudSchema.firstColumn) {
const tableSchemaItem = {
type: crudSchema.firstColumn,
width: '50px'
}
tableSchema.push(tableSchemaItem)
}
// 主键ID // 主键ID
if (crudSchema.primaryKey && crudSchema.primaryType) { if (crudSchema.primaryKey && crudSchema.primaryType) {
const primaryTitle = crudSchema.primaryTitle ? crudSchema.primaryTitle : t('common.index') const primaryTitle = crudSchema.primaryTitle ? crudSchema.primaryTitle : t('common.index')

View File

@ -2,10 +2,13 @@ import { ref, unref } from 'vue'
import { XTableProps } from '@/components/XTable/src/type' import { XTableProps } from '@/components/XTable/src/type'
export interface tableMethod { export interface tableMethod {
reload: () => void reload: () => void // 刷新表格
setProps: (props: XTableProps) => void setProps: (props: XTableProps) => void
deleteData: (ids: string | number) => void deleteData: (ids: string | number) => void // 删除数据
exportList: (fileName?: string) => void exportList: (fileName?: string) => void // 导出列表
getCurrentColumn: () => void // 获取当前列
getRadioRecord: () => void // 获取当前选中列redio
getCheckboxRecords: () => void //获取当前选中列, checkbox
} }
export const useXTable = (props: XTableProps): [Function, tableMethod] => { export const useXTable = (props: XTableProps): [Function, tableMethod] => {
@ -26,7 +29,10 @@ export const useXTable = (props: XTableProps): [Function, tableMethod] => {
reload: () => getInstance().reload(), reload: () => getInstance().reload(),
setProps: (props) => getInstance().setProps(props), setProps: (props) => getInstance().setProps(props),
deleteData: (ids: string | number) => getInstance().deleteData(ids), deleteData: (ids: string | number) => getInstance().deleteData(ids),
exportList: (fileName?: string) => getInstance().exportList(fileName) exportList: (fileName?: string) => getInstance().exportList(fileName),
getCurrentColumn: () => getInstance().getCheckboxRecords(),
getRadioRecord: () => getInstance().getRadioRecord(),
getCheckboxRecords: () => getInstance().getCheckboxRecords()
} }
return [register, methods] return [register, methods]
} }

View File

@ -76,20 +76,20 @@ VXETable.setup({
}, },
pagerConfig: { pagerConfig: {
border: false, border: false,
background: true, background: false,
autoHidden: true, autoHidden: true,
perfect: true, perfect: true,
pageSize: 10, pageSize: 10,
pagerCount: 7, pagerCount: 7,
pageSizes: [5, 10, 15, 20, 50, 100, 200, 500], pageSizes: [5, 10, 15, 20, 50, 100, 200, 500],
layouts: [ layouts: [
'Sizes',
'PrevJump', 'PrevJump',
'PrevPage', 'PrevPage',
'Jump', 'Number',
'PageCount',
'NextPage', 'NextPage',
'NextJump', 'NextJump',
'Sizes', 'FullJump',
'Total' 'Total'
] ]
} }