| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- <template>
- <div class="system-table-box">
- <el-table v-bind="$attrs" ref="table" class="system-table" border height="100%" :data="data"
- @selection-change="handleSelectionChange">
- <el-table-column type="selection" align="center" width="50" v-if="showSelection" />
- <el-table-column label="序号" width="60" align="center" v-if="showIndex">
- <template #default="scope">
- {{ (page.pageNum - 1) * page.pageSize + scope.$index + 1 }}
- </template>
- </el-table-column>
- <slot></slot>
- </el-table>
- <el-pagination v-if="showPage" v-model:current-page="page.pageNum" class="system-page" background :layout="pageLayout"
- :total="page.total" :page-size="page.pageSize" :page-sizes="pageSizes" @current-change="handleCurrentChange"
- @size-change="handleSizeChange">
- </el-pagination>
- </div>
- </template>
- <script lang="js">
- import { defineComponent, ref, onActivated } from 'vue'
- export default defineComponent({
- props: {
- data: { type: Array, default: () => [] }, // 数据源
- select: { type: Array, default: () => [] }, // 已选择的数据,与selection结合使用
- showIndex: { type: Boolean, default: false }, // 是否展示index选择,默认否
- showSelection: { type: Boolean, default: false }, // 是否展示选择框,默认否
- showPage: { type: Boolean, default: true }, // 是否展示页级组件,默认是
- page: { // 分页参数
- type: Object,
- default: () => {
- return { pageNum: 1, pageSize: 20, total: 0 }
- }
- },
- pageLayout: { type: String, default: "total, sizes, prev, pager, next, jumper" }, // 分页需要显示的东西,默认全部
- pageSizes: { type: Array, default: [10, 20, 50, 100] }
- },
- setup(props, context) {
- const table = ref(null)
- let timer = null
- // 分页相关:监听页码切换事件
- const handleCurrentChange = (val) => {
- if (timer) {
- props.page.index = 1
- } else {
- props.page.index = val
- context.emit("getTableData")
- }
- }
- // 分页相关:监听单页显示数量切换事件
- const handleSizeChange = (val) => {
- timer = 'work'
- setTimeout(() => {
- timer = null
- }, 100)
- props.page.size = val
- context.emit("getTableData", true)
- }
- // 选择监听器
- const handleSelectionChange = (val) => {
- context.emit("selection-change", val)
- }
- // 解决BUG:keep-alive组件使用时,表格浮层高度不对的问题
- onActivated(() => {
- table.value.doLayout()
- })
- return {
- table,
- handleCurrentChange,
- handleSizeChange,
- handleSelectionChange
- }
- }
- })
- </script>
- <style lang="scss" scoped>
- .system-table-box {
- display: flex;
- flex-direction: column;
- justify-content: center;
- align-items: flex-start;
- height: 100%;
- .system-table {
- flex: 1;
- height: 100%;
- }
- .system-page {
- margin-top: 20px;
- &::before {
- content: '';
- }
- }
- }
- </style>
|