mirror of
https://gitee.com/huangge1199_admin/vue-pro.git
synced 2025-01-19 11:40:05 +08:00
feat: 调整分页样式,增加获取选中行方法
This commit is contained in:
parent
1fd9056454
commit
28ea779f83
@ -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';
|
||||||
|
@ -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')
|
||||||
|
@ -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]
|
||||||
}
|
}
|
||||||
|
@ -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'
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user