mirror of
https://github.com/pure-admin/vue-pure-admin.git
synced 2025-06-06 00:18:51 +08:00
refactor: use setup refactor
This commit is contained in:
parent
ff329b1e8e
commit
67db3cb1c3
14
.eslintrc.js
14
.eslintrc.js
@ -3,6 +3,20 @@ module.exports = {
|
|||||||
env: {
|
env: {
|
||||||
node: true
|
node: true
|
||||||
},
|
},
|
||||||
|
globals: {
|
||||||
|
// Ref sugar (take 2)
|
||||||
|
$: "readonly",
|
||||||
|
$$: "readonly",
|
||||||
|
$ref: "readonly",
|
||||||
|
$shallowRef: "readonly",
|
||||||
|
$computed: "readonly",
|
||||||
|
|
||||||
|
// script setup
|
||||||
|
defineProps: "readonly",
|
||||||
|
defineEmits: "readonly",
|
||||||
|
defineExpose: "readonly",
|
||||||
|
withDefaults: "readonly"
|
||||||
|
},
|
||||||
extends: [
|
extends: [
|
||||||
"plugin:vue/vue3-essential",
|
"plugin:vue/vue3-essential",
|
||||||
"eslint:recommended",
|
"eslint:recommended",
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
"build": "rimraf dist && cross-env vite build",
|
"build": "rimraf dist && cross-env vite build",
|
||||||
"preview": "vite preview",
|
"preview": "vite preview",
|
||||||
"preview:build": "yarn build && vite preview",
|
"preview:build": "yarn build && vite preview",
|
||||||
"clean:cache": "rm -rf node_modules && yarn cache clean && yarn install",
|
"clean:cache": "rm -rf node_modules && rm -rf .eslintcache && yarn cache clean && yarn install",
|
||||||
"lint:eslint": "eslint --cache --max-warnings 0 \"{src,mock}/**/*.{vue,ts,tsx}\" --fix",
|
"lint:eslint": "eslint --cache --max-warnings 0 \"{src,mock}/**/*.{vue,ts,tsx}\" --fix",
|
||||||
"lint:prettier": "prettier --write \"src/**/*.{js,json,tsx,css,less,scss,vue,html,md}\"",
|
"lint:prettier": "prettier --write \"src/**/*.{js,json,tsx,css,less,scss,vue,html,md}\"",
|
||||||
"lint:stylelint": "stylelint --cache --fix \"**/*.{vue,css,scss,postcss,less}\" --cache --cache-location node_modules/.cache/stylelint/",
|
"lint:stylelint": "stylelint --cache --fix \"**/*.{vue,css,scss,postcss,less}\" --cache --cache-location node_modules/.cache/stylelint/",
|
||||||
|
@ -30,4 +30,5 @@ propTypes.extend([
|
|||||||
type: undefined
|
type: undefined
|
||||||
}
|
}
|
||||||
]);
|
]);
|
||||||
|
|
||||||
export { propTypes };
|
export { propTypes };
|
||||||
|
@ -4,7 +4,7 @@ import Cropper from "/@/components/ReCropper";
|
|||||||
import img from "./picture.jpeg";
|
import img from "./picture.jpeg";
|
||||||
|
|
||||||
const instance = getCurrentInstance();
|
const instance = getCurrentInstance();
|
||||||
let info = ref<object>("");
|
let info = ref<object>(null);
|
||||||
let cropperImg = ref<string>("");
|
let cropperImg = ref<string>("");
|
||||||
|
|
||||||
const onCropper = (): void => {
|
const onCropper = (): void => {
|
||||||
|
@ -9,8 +9,8 @@ import { onMounted, onBeforeUnmount, ref, unref } from "vue";
|
|||||||
import WangEditor from "wangeditor";
|
import WangEditor from "wangeditor";
|
||||||
|
|
||||||
// eslint-disable-next-line no-undef
|
// eslint-disable-next-line no-undef
|
||||||
const editor = ref<ComponentRef>(null);
|
const editor = ref(null);
|
||||||
const html = ref<HTMLElement>(null);
|
const html = ref(null);
|
||||||
let instance: WangEditor;
|
let instance: WangEditor;
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
|
@ -9,8 +9,7 @@ import { toLogicflowData } from "/@/components/ReFlowChart/src/adpterForTurbo";
|
|||||||
import { BpmnNode } from "/@/components/ReFlowChart/src/config";
|
import { BpmnNode } from "/@/components/ReFlowChart/src/config";
|
||||||
import demoData from "./dataTurbo.json";
|
import demoData from "./dataTurbo.json";
|
||||||
|
|
||||||
// eslint-disable-next-line no-undef
|
let lf = ref(null);
|
||||||
let lf = ref<ElRef>(null);
|
|
||||||
let graphData = ref(null);
|
let graphData = ref(null);
|
||||||
let dataVisible = ref<boolean>(false);
|
let dataVisible = ref<boolean>(false);
|
||||||
let config = ref({
|
let config = ref({
|
||||||
|
@ -1,3 +1,79 @@
|
|||||||
|
<script setup lang="ts">
|
||||||
|
import { reactive } from "vue";
|
||||||
|
import { VxeTableEvents } from "vxe-table";
|
||||||
|
import { templateRef } from "@vueuse/core";
|
||||||
|
|
||||||
|
interface Props {
|
||||||
|
drawer: boolean;
|
||||||
|
drawTitle?: string;
|
||||||
|
direction?: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
withDefaults(defineProps<Props>(), {
|
||||||
|
drawer: false,
|
||||||
|
drawTitle: "",
|
||||||
|
direction: "rtl"
|
||||||
|
});
|
||||||
|
|
||||||
|
const emit = defineEmits<{
|
||||||
|
(e: "handleClose"): void;
|
||||||
|
}>();
|
||||||
|
|
||||||
|
const xTable = templateRef<any>("xTable", null);
|
||||||
|
|
||||||
|
const configData = reactive({
|
||||||
|
tableData: [
|
||||||
|
{
|
||||||
|
name: "禁用",
|
||||||
|
dataval: "0"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "启用",
|
||||||
|
dataval: "1"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
isAllChecked: false,
|
||||||
|
isIndeterminate: false,
|
||||||
|
selectRecords: [] as any[],
|
||||||
|
tablePage: {
|
||||||
|
total: 0,
|
||||||
|
currentPage: 1,
|
||||||
|
pageSize: 10
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// 抽屉关闭
|
||||||
|
function handleClose() {
|
||||||
|
configData.isAllChecked = false;
|
||||||
|
configData.isIndeterminate = false;
|
||||||
|
emit("handleClose");
|
||||||
|
}
|
||||||
|
|
||||||
|
function editConfig(row) {
|
||||||
|
console.log("editConfig", row);
|
||||||
|
}
|
||||||
|
|
||||||
|
function delConfig(row) {
|
||||||
|
console.log("delConfig", row);
|
||||||
|
}
|
||||||
|
|
||||||
|
const changeAllEvent = () => {
|
||||||
|
setTimeout(() => {
|
||||||
|
console.log(xTable);
|
||||||
|
}, 1000);
|
||||||
|
const $table = xTable.value;
|
||||||
|
$table.setAllCheckboxRow(configData.isAllChecked);
|
||||||
|
configData.selectRecords = $table.getCheckboxRecords();
|
||||||
|
};
|
||||||
|
|
||||||
|
const checkboxChangeEvent: VxeTableEvents.CheckboxChange = ({ records }) => {
|
||||||
|
const $table = xTable.value;
|
||||||
|
configData.isAllChecked = $table.isAllCheckboxChecked();
|
||||||
|
configData.isIndeterminate = $table.isCheckboxIndeterminate();
|
||||||
|
configData.selectRecords = records;
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="config">
|
<div class="config">
|
||||||
<el-drawer
|
<el-drawer
|
||||||
@ -14,7 +90,7 @@
|
|||||||
<vxe-table
|
<vxe-table
|
||||||
ref="xTable"
|
ref="xTable"
|
||||||
border
|
border
|
||||||
:data="tableData"
|
:data="configData.tableData"
|
||||||
@checkbox-change="checkboxChangeEvent"
|
@checkbox-change="checkboxChangeEvent"
|
||||||
@checkbox-all="checkboxChangeEvent"
|
@checkbox-all="checkboxChangeEvent"
|
||||||
>
|
>
|
||||||
@ -40,9 +116,9 @@
|
|||||||
</vxe-table>
|
</vxe-table>
|
||||||
<vxe-pager
|
<vxe-pager
|
||||||
perfect
|
perfect
|
||||||
v-model:current-page="tablePage.currentPage"
|
v-model:current-page="configData.tablePage.currentPage"
|
||||||
v-model:page-size="tablePage.pageSize"
|
v-model:page-size="configData.tablePage.pageSize"
|
||||||
:total="tablePage.total"
|
:total="configData.tablePage.total"
|
||||||
:layouts="[
|
:layouts="[
|
||||||
'PrevJump',
|
'PrevJump',
|
||||||
'PrevPage',
|
'PrevPage',
|
||||||
@ -57,12 +133,12 @@
|
|||||||
<template #left>
|
<template #left>
|
||||||
<span class="page-left">
|
<span class="page-left">
|
||||||
<vxe-checkbox
|
<vxe-checkbox
|
||||||
v-model="isAllChecked"
|
v-model="configData.isAllChecked"
|
||||||
:indeterminate="isIndeterminate"
|
:indeterminate="configData.isIndeterminate"
|
||||||
@change="changeAllEvent"
|
@change="changeAllEvent"
|
||||||
></vxe-checkbox>
|
></vxe-checkbox>
|
||||||
<span class="select-count"
|
<span class="select-count"
|
||||||
>已选中{{ selectRecords.length }}条</span
|
>已选中{{ configData.selectRecords.length }}条</span
|
||||||
>
|
>
|
||||||
<vxe-button size="small">{{ $t("message.hsdelete") }}</vxe-button>
|
<vxe-button size="small">{{ $t("message.hsdelete") }}</vxe-button>
|
||||||
</span>
|
</span>
|
||||||
@ -73,98 +149,6 @@
|
|||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts">
|
|
||||||
import { defineComponent, reactive, toRefs } from "vue";
|
|
||||||
import { propTypes } from "/@/utils/propTypes";
|
|
||||||
import { VxeTableEvents } from "vxe-table";
|
|
||||||
import { templateRef } from "@vueuse/core";
|
|
||||||
|
|
||||||
export default defineComponent({
|
|
||||||
props: {
|
|
||||||
drawer: propTypes.bool.def(false),
|
|
||||||
drawTitle: propTypes.string.def(""),
|
|
||||||
direction: propTypes.string.def("rtl")
|
|
||||||
},
|
|
||||||
emits: ["handleClose"],
|
|
||||||
setup(props, ctx) {
|
|
||||||
const { emit } = ctx;
|
|
||||||
|
|
||||||
const xTable = templateRef<any>("xTable", null);
|
|
||||||
|
|
||||||
const configData = reactive({
|
|
||||||
tableData: [
|
|
||||||
{
|
|
||||||
name: "禁用",
|
|
||||||
dataval: "0"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: "启用",
|
|
||||||
dataval: "1"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
isAllChecked: false,
|
|
||||||
isIndeterminate: false,
|
|
||||||
selectRecords: [] as any[],
|
|
||||||
tablePage: {
|
|
||||||
total: 0,
|
|
||||||
currentPage: 1,
|
|
||||||
pageSize: 10
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
// 抽屉关闭
|
|
||||||
function handleClose() {
|
|
||||||
configData.isAllChecked = false;
|
|
||||||
configData.isIndeterminate = false;
|
|
||||||
emit("handleClose");
|
|
||||||
}
|
|
||||||
|
|
||||||
function editConfig(row) {
|
|
||||||
console.log(
|
|
||||||
"%crow===>>>: ",
|
|
||||||
"color: MidnightBlue; background: Aquamarine; font-size: 20px;",
|
|
||||||
row
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
function delConfig(row) {
|
|
||||||
console.log(
|
|
||||||
"%crow===>>>: ",
|
|
||||||
"color: MidnightBlue; background: Aquamarine; font-size: 20px;",
|
|
||||||
row
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
const changeAllEvent = () => {
|
|
||||||
setTimeout(() => {
|
|
||||||
console.log(xTable);
|
|
||||||
}, 1000);
|
|
||||||
const $table = xTable.value;
|
|
||||||
$table.setAllCheckboxRow(configData.isAllChecked);
|
|
||||||
configData.selectRecords = $table.getCheckboxRecords();
|
|
||||||
};
|
|
||||||
|
|
||||||
const checkboxChangeEvent: VxeTableEvents.CheckboxChange = ({
|
|
||||||
records
|
|
||||||
}) => {
|
|
||||||
const $table = xTable.value;
|
|
||||||
configData.isAllChecked = $table.isAllCheckboxChecked();
|
|
||||||
configData.isIndeterminate = $table.isCheckboxIndeterminate();
|
|
||||||
configData.selectRecords = records;
|
|
||||||
};
|
|
||||||
|
|
||||||
return {
|
|
||||||
...toRefs(configData),
|
|
||||||
handleClose,
|
|
||||||
editConfig,
|
|
||||||
delConfig,
|
|
||||||
changeAllEvent,
|
|
||||||
checkboxChangeEvent
|
|
||||||
};
|
|
||||||
}
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
.list {
|
.list {
|
||||||
padding: 10px;
|
padding: 10px;
|
||||||
|
@ -1,10 +1,208 @@
|
|||||||
|
<script setup lang="ts">
|
||||||
|
import Config from "./config.vue";
|
||||||
|
import { reactive, ref, unref, nextTick } from "vue";
|
||||||
|
import XEUtils from "xe-utils";
|
||||||
|
import { cloneDeep } from "lodash-es";
|
||||||
|
import { templateRef } from "@vueuse/core";
|
||||||
|
import { useCopyToClipboard } from "/@/utils/useCopyToClipboard";
|
||||||
|
import {
|
||||||
|
VXETable,
|
||||||
|
VxeTableInstance,
|
||||||
|
VxeTableEvents,
|
||||||
|
VxeFormPropTypes
|
||||||
|
} from "vxe-table";
|
||||||
|
type onEditNRow = {
|
||||||
|
name: string;
|
||||||
|
model: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
const dictData = reactive({
|
||||||
|
submitLoading: false,
|
||||||
|
showEdit: false,
|
||||||
|
selectRow: null,
|
||||||
|
filterName: "",
|
||||||
|
tableData: [
|
||||||
|
{
|
||||||
|
id: 1,
|
||||||
|
name: "状态",
|
||||||
|
model: "",
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
id: "1-1",
|
||||||
|
name: "服务状态",
|
||||||
|
model: "serviceStatus"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: "1-2",
|
||||||
|
name: "在线状态",
|
||||||
|
model: "onlienStatus"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{ id: 2, name: "操作系统", model: "operatingSystem" }
|
||||||
|
],
|
||||||
|
formData: {
|
||||||
|
name: "",
|
||||||
|
model: ""
|
||||||
|
},
|
||||||
|
formItems: [
|
||||||
|
{
|
||||||
|
field: "name",
|
||||||
|
title: "字典名称",
|
||||||
|
span: 24,
|
||||||
|
itemRender: {
|
||||||
|
name: "$input",
|
||||||
|
props: { placeholder: "请输入字典名称" }
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: "model",
|
||||||
|
title: "字典类型",
|
||||||
|
span: 24,
|
||||||
|
itemRender: {
|
||||||
|
name: "$input",
|
||||||
|
props: {
|
||||||
|
placeholder: "请输入字典类型",
|
||||||
|
//这里vxe-table文档并没有提到,可以配置所选组件的所有属性,比如这里可以配置关于vxe-input的所有属性
|
||||||
|
disabled: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
align: "right",
|
||||||
|
span: 24,
|
||||||
|
itemRender: {
|
||||||
|
name: "$buttons",
|
||||||
|
children: [
|
||||||
|
{ props: { type: "submit", content: "提交", status: "primary" } },
|
||||||
|
{ props: { type: "reset", content: "重置" } }
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
] as VxeFormPropTypes.Items
|
||||||
|
});
|
||||||
|
|
||||||
|
let originData = cloneDeep(dictData.tableData);
|
||||||
|
|
||||||
|
const xTree = templateRef<HTMLElement | any>("xTree", null);
|
||||||
|
|
||||||
|
const handleSearch = () => {
|
||||||
|
const filterName = XEUtils.toValueString(dictData.filterName).trim();
|
||||||
|
|
||||||
|
if (filterName) {
|
||||||
|
const options = { children: "children" };
|
||||||
|
const searchProps = ["name"];
|
||||||
|
|
||||||
|
dictData.tableData = XEUtils.searchTree(
|
||||||
|
originData,
|
||||||
|
item =>
|
||||||
|
searchProps.some(
|
||||||
|
key => XEUtils.toValueString(item[key]).indexOf(filterName) > -1
|
||||||
|
),
|
||||||
|
options
|
||||||
|
);
|
||||||
|
|
||||||
|
// 搜索之后默认展开所有子节点
|
||||||
|
nextTick(() => {
|
||||||
|
const $table = xTree.value;
|
||||||
|
$table.setAllTreeExpand(true);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
dictData.tableData = originData;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// 创建一个防防抖函数,调用频率间隔 100 毫秒
|
||||||
|
const searchEvent = XEUtils.debounce(
|
||||||
|
function () {
|
||||||
|
handleSearch();
|
||||||
|
},
|
||||||
|
100,
|
||||||
|
{ leading: false, trailing: true }
|
||||||
|
);
|
||||||
|
|
||||||
|
const confirmEvent = async () => {
|
||||||
|
const type = await VXETable.modal.confirm("您确定要删除吗?");
|
||||||
|
(await type) === "confirm" &&
|
||||||
|
VXETable.modal.message({
|
||||||
|
content: "测试数据,不可删除",
|
||||||
|
status: "error"
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function commonFn(value, disabled) {
|
||||||
|
dictData.selectRow = value;
|
||||||
|
dictData.showEdit = true;
|
||||||
|
dictData.formItems[1].itemRender.props.disabled = disabled;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 新增
|
||||||
|
function onAdd() {
|
||||||
|
commonFn(null, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 新增子类型
|
||||||
|
function onAddChild(row?: object) {
|
||||||
|
console.log("onAddChild", row);
|
||||||
|
commonFn(null, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 编辑
|
||||||
|
function onEdit(row?: onEditNRow) {
|
||||||
|
dictData.formData = {
|
||||||
|
name: row.name,
|
||||||
|
model: row.model ? row.model : "暂无字典类型"
|
||||||
|
};
|
||||||
|
commonFn(row, true);
|
||||||
|
// VXETable.modal.message({
|
||||||
|
// content: "测试数据,不可编辑",
|
||||||
|
// status: "error"
|
||||||
|
// });
|
||||||
|
}
|
||||||
|
|
||||||
|
// 拷贝当前列表项的数据(字典类型)
|
||||||
|
const { clipboardRef } = useCopyToClipboard();
|
||||||
|
const cellDBLClickEvent: VxeTableEvents.CellDblclick = ({ row }) => {
|
||||||
|
clipboardRef.value = unref(row).model;
|
||||||
|
};
|
||||||
|
|
||||||
|
const xTable = ref({} as VxeTableInstance);
|
||||||
|
|
||||||
|
const submitEvent = () => {
|
||||||
|
dictData.submitLoading = true;
|
||||||
|
setTimeout(() => {
|
||||||
|
const $table = xTable.value;
|
||||||
|
dictData.submitLoading = false;
|
||||||
|
dictData.showEdit = false;
|
||||||
|
if (dictData.selectRow) {
|
||||||
|
VXETable.modal.message({ content: "保存成功", status: "success" });
|
||||||
|
Object.assign(dictData.selectRow, dictData.formData);
|
||||||
|
} else {
|
||||||
|
VXETable.modal.message({ content: "新增成功", status: "success" });
|
||||||
|
$table.insert(dictData.formData);
|
||||||
|
}
|
||||||
|
}, 500);
|
||||||
|
};
|
||||||
|
|
||||||
|
let drawer = ref(false);
|
||||||
|
|
||||||
|
function onDeploy(value?: object) {
|
||||||
|
console.log("onDeploy", value);
|
||||||
|
drawer.value = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
function handleClose() {
|
||||||
|
drawer.value = false;
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="dict-container">
|
<div class="dict-container">
|
||||||
<!-- 工具栏 -->
|
<!-- 工具栏 -->
|
||||||
<vxe-toolbar>
|
<vxe-toolbar>
|
||||||
<template #buttons>
|
<template #buttons>
|
||||||
<vxe-input
|
<vxe-input
|
||||||
v-model="filterName"
|
v-model="dictData.filterName"
|
||||||
:placeholder="$t('message.hssearch')"
|
:placeholder="$t('message.hssearch')"
|
||||||
@keyup="searchEvent"
|
@keyup="searchEvent"
|
||||||
></vxe-input>
|
></vxe-input>
|
||||||
@ -41,7 +239,7 @@
|
|||||||
iconOpen: 'fa fa-minus-square-o',
|
iconOpen: 'fa fa-minus-square-o',
|
||||||
iconClose: 'fa fa-plus-square-o'
|
iconClose: 'fa fa-plus-square-o'
|
||||||
}"
|
}"
|
||||||
:data="tableData"
|
:data="dictData.tableData"
|
||||||
@cell-dblclick="cellDBLClickEvent"
|
@cell-dblclick="cellDBLClickEvent"
|
||||||
>
|
>
|
||||||
<vxe-table-column
|
<vxe-table-column
|
||||||
@ -89,16 +287,16 @@
|
|||||||
<vxe-modal
|
<vxe-modal
|
||||||
resize
|
resize
|
||||||
width="450"
|
width="450"
|
||||||
v-model="showEdit"
|
v-model="dictData.showEdit"
|
||||||
:title="selectRow ? '编辑' : '新增'"
|
:title="dictData.selectRow ? '编辑' : '新增'"
|
||||||
:loading="submitLoading"
|
:loading="dictData.submitLoading"
|
||||||
@hide="$refs.xForm.reset()"
|
@hide="$refs.xForm.reset()"
|
||||||
>
|
>
|
||||||
<template #default>
|
<template #default>
|
||||||
<vxe-form
|
<vxe-form
|
||||||
ref="xForm"
|
ref="xForm"
|
||||||
:data="formData"
|
:data="dictData.formData"
|
||||||
:items="formItems"
|
:items="dictData.formItems"
|
||||||
title-align="right"
|
title-align="right"
|
||||||
title-width="100"
|
title-width="100"
|
||||||
@submit="submitEvent"
|
@submit="submitEvent"
|
||||||
@ -109,229 +307,7 @@
|
|||||||
<Config :drawer="drawer" drawTitle="字典列表" @handleClose="handleClose" />
|
<Config :drawer="drawer" drawTitle="字典列表" @handleClose="handleClose" />
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script lang="ts">
|
|
||||||
import { reactive, ref, unref, nextTick, toRefs } from "vue";
|
|
||||||
import XEUtils from "xe-utils";
|
|
||||||
import { cloneDeep } from "lodash-es";
|
|
||||||
import { templateRef } from "@vueuse/core";
|
|
||||||
import { useCopyToClipboard } from "/@/utils/useCopyToClipboard";
|
|
||||||
import {
|
|
||||||
VXETable,
|
|
||||||
VxeTableInstance,
|
|
||||||
VxeTableEvents,
|
|
||||||
VxeFormPropTypes
|
|
||||||
} from "vxe-table";
|
|
||||||
import Config from "./config.vue";
|
|
||||||
|
|
||||||
export default {
|
|
||||||
name: "dict",
|
|
||||||
components: {
|
|
||||||
Config
|
|
||||||
},
|
|
||||||
setup() {
|
|
||||||
const dictData = reactive({
|
|
||||||
submitLoading: false,
|
|
||||||
showEdit: false,
|
|
||||||
selectRow: null,
|
|
||||||
filterName: "",
|
|
||||||
tableData: [
|
|
||||||
{
|
|
||||||
id: 1,
|
|
||||||
name: "状态",
|
|
||||||
model: "",
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
id: "1-1",
|
|
||||||
name: "服务状态",
|
|
||||||
model: "serviceStatus"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: "1-2",
|
|
||||||
name: "在线状态",
|
|
||||||
model: "onlienStatus"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{ id: 2, name: "操作系统", model: "operatingSystem" }
|
|
||||||
],
|
|
||||||
formData: {
|
|
||||||
name: "",
|
|
||||||
model: ""
|
|
||||||
},
|
|
||||||
formItems: [
|
|
||||||
{
|
|
||||||
field: "name",
|
|
||||||
title: "字典名称",
|
|
||||||
span: 24,
|
|
||||||
itemRender: {
|
|
||||||
name: "$input",
|
|
||||||
props: { placeholder: "请输入字典名称" }
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
field: "model",
|
|
||||||
title: "字典类型",
|
|
||||||
span: 24,
|
|
||||||
itemRender: {
|
|
||||||
name: "$input",
|
|
||||||
props: {
|
|
||||||
placeholder: "请输入字典类型",
|
|
||||||
//这里vxe-table文档并没有提到,可以配置所选组件的所有属性,比如这里可以配置关于vxe-input的所有属性
|
|
||||||
disabled: true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
align: "right",
|
|
||||||
span: 24,
|
|
||||||
itemRender: {
|
|
||||||
name: "$buttons",
|
|
||||||
children: [
|
|
||||||
{ props: { type: "submit", content: "提交", status: "primary" } },
|
|
||||||
{ props: { type: "reset", content: "重置" } }
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
] as VxeFormPropTypes.Items
|
|
||||||
});
|
|
||||||
|
|
||||||
let originData = cloneDeep(dictData.tableData);
|
|
||||||
|
|
||||||
const xTree = templateRef<HTMLElement | any>("xTree", null);
|
|
||||||
|
|
||||||
const formatDate = (value: any) => {
|
|
||||||
return XEUtils.toDateString(value, "yyyy-MM-dd HH:mm:ss.S");
|
|
||||||
};
|
|
||||||
|
|
||||||
const handleSearch = () => {
|
|
||||||
const filterName = XEUtils.toValueString(dictData.filterName).trim();
|
|
||||||
|
|
||||||
if (filterName) {
|
|
||||||
const options = { children: "children" };
|
|
||||||
const searchProps = ["name"];
|
|
||||||
|
|
||||||
dictData.tableData = XEUtils.searchTree(
|
|
||||||
originData,
|
|
||||||
item =>
|
|
||||||
searchProps.some(
|
|
||||||
key => XEUtils.toValueString(item[key]).indexOf(filterName) > -1
|
|
||||||
),
|
|
||||||
options
|
|
||||||
);
|
|
||||||
|
|
||||||
// 搜索之后默认展开所有子节点
|
|
||||||
nextTick(() => {
|
|
||||||
const $table = xTree.value;
|
|
||||||
$table.setAllTreeExpand(true);
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
dictData.tableData = originData;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// 创建一个防防抖函数,调用频率间隔 100 毫秒
|
|
||||||
const searchEvent = XEUtils.debounce(
|
|
||||||
function () {
|
|
||||||
handleSearch();
|
|
||||||
},
|
|
||||||
100,
|
|
||||||
{ leading: false, trailing: true }
|
|
||||||
);
|
|
||||||
|
|
||||||
const confirmEvent = async () => {
|
|
||||||
const type = await VXETable.modal.confirm("您确定要删除吗?");
|
|
||||||
(await type) === "confirm" &&
|
|
||||||
VXETable.modal.message({
|
|
||||||
content: "测试数据,不可删除",
|
|
||||||
status: "error"
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
function commonFn(value, disabled) {
|
|
||||||
dictData.selectRow = value;
|
|
||||||
dictData.showEdit = true;
|
|
||||||
dictData.formItems[1].itemRender.props.disabled = disabled;
|
|
||||||
}
|
|
||||||
|
|
||||||
// 新增
|
|
||||||
function onAdd() {
|
|
||||||
commonFn(null, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 新增子类型
|
|
||||||
function onAddChild(row: any) {
|
|
||||||
console.log(
|
|
||||||
"%crow===>>>: ",
|
|
||||||
"color: MidnightBlue; background: Aquamarine; font-size: 20px;",
|
|
||||||
row
|
|
||||||
);
|
|
||||||
commonFn(null, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 编辑
|
|
||||||
function onEdit(row: any) {
|
|
||||||
dictData.formData = {
|
|
||||||
name: row.name,
|
|
||||||
model: row.model ? row.model : "暂无字典类型"
|
|
||||||
};
|
|
||||||
commonFn(row, true);
|
|
||||||
// VXETable.modal.message({
|
|
||||||
// content: "测试数据,不可编辑",
|
|
||||||
// status: "error"
|
|
||||||
// });
|
|
||||||
}
|
|
||||||
|
|
||||||
// 拷贝当前列表项的数据(字典类型)
|
|
||||||
const { clipboardRef } = useCopyToClipboard();
|
|
||||||
const cellDBLClickEvent: VxeTableEvents.CellDblclick = ({ row }) => {
|
|
||||||
clipboardRef.value = unref(row).model;
|
|
||||||
};
|
|
||||||
|
|
||||||
const xTable = ref({} as VxeTableInstance);
|
|
||||||
|
|
||||||
const submitEvent = () => {
|
|
||||||
dictData.submitLoading = true;
|
|
||||||
setTimeout(() => {
|
|
||||||
const $table = xTable.value;
|
|
||||||
dictData.submitLoading = false;
|
|
||||||
dictData.showEdit = false;
|
|
||||||
if (dictData.selectRow) {
|
|
||||||
VXETable.modal.message({ content: "保存成功", status: "success" });
|
|
||||||
Object.assign(dictData.selectRow, dictData.formData);
|
|
||||||
} else {
|
|
||||||
VXETable.modal.message({ content: "新增成功", status: "success" });
|
|
||||||
$table.insert(dictData.formData);
|
|
||||||
}
|
|
||||||
}, 500);
|
|
||||||
};
|
|
||||||
|
|
||||||
let drawer = ref(false);
|
|
||||||
|
|
||||||
function onDeploy() {
|
|
||||||
drawer.value = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
function handleClose() {
|
|
||||||
drawer.value = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
|
||||||
...toRefs(dictData),
|
|
||||||
formatDate,
|
|
||||||
searchEvent,
|
|
||||||
confirmEvent,
|
|
||||||
cellDBLClickEvent,
|
|
||||||
submitEvent,
|
|
||||||
onEdit,
|
|
||||||
onAddChild,
|
|
||||||
onAdd,
|
|
||||||
onDeploy,
|
|
||||||
drawer,
|
|
||||||
handleClose
|
|
||||||
};
|
|
||||||
}
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
.dict-container {
|
.dict-container {
|
||||||
margin: 10px;
|
margin: 10px;
|
||||||
|
@ -1,252 +1,242 @@
|
|||||||
|
<script setup lang="ts">
|
||||||
|
import { reactive } from "vue";
|
||||||
|
import { VxeGridProps } from "vxe-table";
|
||||||
|
|
||||||
|
const gridOptions = reactive({
|
||||||
|
border: true,
|
||||||
|
resizable: true,
|
||||||
|
keepSource: true,
|
||||||
|
height: 500,
|
||||||
|
printConfig: {},
|
||||||
|
importConfig: {},
|
||||||
|
exportConfig: {},
|
||||||
|
pagerConfig: {
|
||||||
|
perfect: true,
|
||||||
|
pageSize: 15
|
||||||
|
},
|
||||||
|
editConfig: {
|
||||||
|
trigger: "click",
|
||||||
|
mode: "row",
|
||||||
|
showStatus: true
|
||||||
|
},
|
||||||
|
toolbarConfig: {
|
||||||
|
buttons: [
|
||||||
|
{
|
||||||
|
code: "insert_actived",
|
||||||
|
name: "message.hsadd",
|
||||||
|
status: "perfect",
|
||||||
|
icon: "fa fa-plus"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
code: "mark_cancel",
|
||||||
|
name: "message.hsmark",
|
||||||
|
status: "perfect",
|
||||||
|
icon: "fa fa-trash-o"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
code: "save",
|
||||||
|
name: "message.hssave",
|
||||||
|
status: "perfect",
|
||||||
|
icon: "fa fa-save"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
perfect: true,
|
||||||
|
refresh: {
|
||||||
|
icon: "fa fa-refresh",
|
||||||
|
iconLoading: "fa fa-spinner fa-spin"
|
||||||
|
},
|
||||||
|
import: {
|
||||||
|
icon: "fa fa-upload"
|
||||||
|
},
|
||||||
|
export: {
|
||||||
|
icon: "fa fa-download"
|
||||||
|
},
|
||||||
|
print: {
|
||||||
|
icon: "fa fa-print"
|
||||||
|
},
|
||||||
|
zoom: {
|
||||||
|
iconIn: "fa fa-arrows-alt",
|
||||||
|
iconOut: "fa fa-expand"
|
||||||
|
},
|
||||||
|
custom: {
|
||||||
|
icon: "fa fa-cog"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
proxyConfig: {
|
||||||
|
props: {
|
||||||
|
result: "result",
|
||||||
|
total: "page.total"
|
||||||
|
},
|
||||||
|
ajax: {
|
||||||
|
// 接收 Promise
|
||||||
|
query: ({ page }) => {
|
||||||
|
return new Promise(resolve => {
|
||||||
|
setTimeout(() => {
|
||||||
|
const list = [
|
||||||
|
{
|
||||||
|
id: 10001,
|
||||||
|
name: "Test1",
|
||||||
|
nickname: "T1",
|
||||||
|
role: "Develop",
|
||||||
|
sex: "Man",
|
||||||
|
age: 28,
|
||||||
|
address: "Shenzhen"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 10002,
|
||||||
|
name: "Test2",
|
||||||
|
nickname: "T2",
|
||||||
|
role: "Test",
|
||||||
|
sex: "Women",
|
||||||
|
age: 22,
|
||||||
|
address: "Guangzhou"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 10003,
|
||||||
|
name: "Test3",
|
||||||
|
nickname: "T3",
|
||||||
|
role: "PM",
|
||||||
|
sex: "Man",
|
||||||
|
age: 32,
|
||||||
|
address: "Shanghai"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 10004,
|
||||||
|
name: "Test4",
|
||||||
|
nickname: "T4",
|
||||||
|
role: "Designer",
|
||||||
|
sex: "Women ",
|
||||||
|
age: 23,
|
||||||
|
address: "Shenzhen"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 10005,
|
||||||
|
name: "Test5",
|
||||||
|
nickname: "T5",
|
||||||
|
role: "Develop",
|
||||||
|
sex: "Women ",
|
||||||
|
age: 30,
|
||||||
|
address: "Shanghai"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 10006,
|
||||||
|
name: "Test6",
|
||||||
|
nickname: "T6",
|
||||||
|
role: "Designer",
|
||||||
|
sex: "Women ",
|
||||||
|
age: 21,
|
||||||
|
address: "Shenzhen"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 10007,
|
||||||
|
name: "Test7",
|
||||||
|
nickname: "T7",
|
||||||
|
role: "Test",
|
||||||
|
sex: "Man ",
|
||||||
|
age: 29,
|
||||||
|
address: "vxe-table 从入门到放弃"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 10008,
|
||||||
|
name: "Test8",
|
||||||
|
nickname: "T8",
|
||||||
|
role: "Develop",
|
||||||
|
sex: "Man ",
|
||||||
|
age: 35,
|
||||||
|
address: "Shenzhen"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 10009,
|
||||||
|
name: "Test9",
|
||||||
|
nickname: "T9",
|
||||||
|
role: "Develop",
|
||||||
|
sex: "Man ",
|
||||||
|
age: 35,
|
||||||
|
address: "Shenzhen"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 100010,
|
||||||
|
name: "Test10",
|
||||||
|
nickname: "T10",
|
||||||
|
role: "Develop",
|
||||||
|
sex: "Man ",
|
||||||
|
age: 35,
|
||||||
|
address: "Guangzhou"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 100011,
|
||||||
|
name: "Test11",
|
||||||
|
nickname: "T11",
|
||||||
|
role: "Test",
|
||||||
|
sex: "Women ",
|
||||||
|
age: 26,
|
||||||
|
address: "vxe-table 从入门到放弃"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 100012,
|
||||||
|
name: "Test12",
|
||||||
|
nickname: "T12",
|
||||||
|
role: "Develop",
|
||||||
|
sex: "Man ",
|
||||||
|
age: 34,
|
||||||
|
address: "Guangzhou"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 100013,
|
||||||
|
name: "Test13",
|
||||||
|
nickname: "T13",
|
||||||
|
role: "Test",
|
||||||
|
sex: "Women ",
|
||||||
|
age: 22,
|
||||||
|
address: "Shenzhen"
|
||||||
|
}
|
||||||
|
];
|
||||||
|
resolve({
|
||||||
|
page: {
|
||||||
|
total: list.length
|
||||||
|
},
|
||||||
|
result: list.slice(
|
||||||
|
(page.currentPage - 1) * page.pageSize,
|
||||||
|
page.currentPage * page.pageSize
|
||||||
|
)
|
||||||
|
});
|
||||||
|
}, 100);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
// body 对象: { removeRecords }
|
||||||
|
delete: () => {
|
||||||
|
return new Promise(resolve => {
|
||||||
|
setTimeout(() => {
|
||||||
|
resolve({});
|
||||||
|
}, 100);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
// body 对象: { insertRecords, updateRecords, removeRecords, pendingRecords }
|
||||||
|
save: () => {
|
||||||
|
return new Promise(resolve => {
|
||||||
|
setTimeout(() => {
|
||||||
|
resolve({});
|
||||||
|
}, 100);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
columns: [
|
||||||
|
{ type: "checkbox", width: 50 },
|
||||||
|
{ type: "seq", width: 60 },
|
||||||
|
{ field: "name", title: "Name", editRender: { name: "input" } },
|
||||||
|
{ field: "nickname", title: "Nickname", editRender: { name: "input" } },
|
||||||
|
{ field: "role", title: "Role", editRender: { name: "input" } },
|
||||||
|
{
|
||||||
|
field: "address",
|
||||||
|
title: "Address",
|
||||||
|
showOverflow: true,
|
||||||
|
editRender: { name: "input" }
|
||||||
|
}
|
||||||
|
]
|
||||||
|
} as VxeGridProps);
|
||||||
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<vxe-grid v-bind="gridOptions" style="width: 98%"></vxe-grid>
|
<vxe-grid v-bind="gridOptions" style="width: 98%"></vxe-grid>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts">
|
|
||||||
import { reactive } from "vue";
|
|
||||||
import { VxeGridProps } from "vxe-table";
|
|
||||||
export default {
|
|
||||||
name: "user",
|
|
||||||
setup() {
|
|
||||||
const gridOptions = reactive({
|
|
||||||
border: true,
|
|
||||||
resizable: true,
|
|
||||||
keepSource: true,
|
|
||||||
height: 500,
|
|
||||||
printConfig: {},
|
|
||||||
importConfig: {},
|
|
||||||
exportConfig: {},
|
|
||||||
pagerConfig: {
|
|
||||||
perfect: true,
|
|
||||||
pageSize: 15
|
|
||||||
},
|
|
||||||
editConfig: {
|
|
||||||
trigger: "click",
|
|
||||||
mode: "row",
|
|
||||||
showStatus: true
|
|
||||||
},
|
|
||||||
toolbarConfig: {
|
|
||||||
buttons: [
|
|
||||||
{
|
|
||||||
code: "insert_actived",
|
|
||||||
name: "message.hsadd",
|
|
||||||
status: "perfect",
|
|
||||||
icon: "fa fa-plus"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
code: "mark_cancel",
|
|
||||||
name: "message.hsmark",
|
|
||||||
status: "perfect",
|
|
||||||
icon: "fa fa-trash-o"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
code: "save",
|
|
||||||
name: "message.hssave",
|
|
||||||
status: "perfect",
|
|
||||||
icon: "fa fa-save"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
perfect: true,
|
|
||||||
refresh: {
|
|
||||||
icon: "fa fa-refresh",
|
|
||||||
iconLoading: "fa fa-spinner fa-spin"
|
|
||||||
},
|
|
||||||
import: {
|
|
||||||
icon: "fa fa-upload"
|
|
||||||
},
|
|
||||||
export: {
|
|
||||||
icon: "fa fa-download"
|
|
||||||
},
|
|
||||||
print: {
|
|
||||||
icon: "fa fa-print"
|
|
||||||
},
|
|
||||||
zoom: {
|
|
||||||
iconIn: "fa fa-arrows-alt",
|
|
||||||
iconOut: "fa fa-expand"
|
|
||||||
},
|
|
||||||
custom: {
|
|
||||||
icon: "fa fa-cog"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
proxyConfig: {
|
|
||||||
props: {
|
|
||||||
result: "result",
|
|
||||||
total: "page.total"
|
|
||||||
},
|
|
||||||
ajax: {
|
|
||||||
// 接收 Promise
|
|
||||||
query: ({ page }) => {
|
|
||||||
return new Promise(resolve => {
|
|
||||||
setTimeout(() => {
|
|
||||||
const list = [
|
|
||||||
{
|
|
||||||
id: 10001,
|
|
||||||
name: "Test1",
|
|
||||||
nickname: "T1",
|
|
||||||
role: "Develop",
|
|
||||||
sex: "Man",
|
|
||||||
age: 28,
|
|
||||||
address: "Shenzhen"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 10002,
|
|
||||||
name: "Test2",
|
|
||||||
nickname: "T2",
|
|
||||||
role: "Test",
|
|
||||||
sex: "Women",
|
|
||||||
age: 22,
|
|
||||||
address: "Guangzhou"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 10003,
|
|
||||||
name: "Test3",
|
|
||||||
nickname: "T3",
|
|
||||||
role: "PM",
|
|
||||||
sex: "Man",
|
|
||||||
age: 32,
|
|
||||||
address: "Shanghai"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 10004,
|
|
||||||
name: "Test4",
|
|
||||||
nickname: "T4",
|
|
||||||
role: "Designer",
|
|
||||||
sex: "Women ",
|
|
||||||
age: 23,
|
|
||||||
address: "Shenzhen"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 10005,
|
|
||||||
name: "Test5",
|
|
||||||
nickname: "T5",
|
|
||||||
role: "Develop",
|
|
||||||
sex: "Women ",
|
|
||||||
age: 30,
|
|
||||||
address: "Shanghai"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 10006,
|
|
||||||
name: "Test6",
|
|
||||||
nickname: "T6",
|
|
||||||
role: "Designer",
|
|
||||||
sex: "Women ",
|
|
||||||
age: 21,
|
|
||||||
address: "Shenzhen"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 10007,
|
|
||||||
name: "Test7",
|
|
||||||
nickname: "T7",
|
|
||||||
role: "Test",
|
|
||||||
sex: "Man ",
|
|
||||||
age: 29,
|
|
||||||
address: "vxe-table 从入门到放弃"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 10008,
|
|
||||||
name: "Test8",
|
|
||||||
nickname: "T8",
|
|
||||||
role: "Develop",
|
|
||||||
sex: "Man ",
|
|
||||||
age: 35,
|
|
||||||
address: "Shenzhen"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 10009,
|
|
||||||
name: "Test9",
|
|
||||||
nickname: "T9",
|
|
||||||
role: "Develop",
|
|
||||||
sex: "Man ",
|
|
||||||
age: 35,
|
|
||||||
address: "Shenzhen"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 100010,
|
|
||||||
name: "Test10",
|
|
||||||
nickname: "T10",
|
|
||||||
role: "Develop",
|
|
||||||
sex: "Man ",
|
|
||||||
age: 35,
|
|
||||||
address: "Guangzhou"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 100011,
|
|
||||||
name: "Test11",
|
|
||||||
nickname: "T11",
|
|
||||||
role: "Test",
|
|
||||||
sex: "Women ",
|
|
||||||
age: 26,
|
|
||||||
address: "vxe-table 从入门到放弃"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 100012,
|
|
||||||
name: "Test12",
|
|
||||||
nickname: "T12",
|
|
||||||
role: "Develop",
|
|
||||||
sex: "Man ",
|
|
||||||
age: 34,
|
|
||||||
address: "Guangzhou"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 100013,
|
|
||||||
name: "Test13",
|
|
||||||
nickname: "T13",
|
|
||||||
role: "Test",
|
|
||||||
sex: "Women ",
|
|
||||||
age: 22,
|
|
||||||
address: "Shenzhen"
|
|
||||||
}
|
|
||||||
];
|
|
||||||
resolve({
|
|
||||||
page: {
|
|
||||||
total: list.length
|
|
||||||
},
|
|
||||||
result: list.slice(
|
|
||||||
(page.currentPage - 1) * page.pageSize,
|
|
||||||
page.currentPage * page.pageSize
|
|
||||||
)
|
|
||||||
});
|
|
||||||
}, 100);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
// body 对象: { removeRecords }
|
|
||||||
delete: () => {
|
|
||||||
return new Promise(resolve => {
|
|
||||||
setTimeout(() => {
|
|
||||||
resolve({});
|
|
||||||
}, 100);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
// body 对象: { insertRecords, updateRecords, removeRecords, pendingRecords }
|
|
||||||
save: () => {
|
|
||||||
return new Promise(resolve => {
|
|
||||||
setTimeout(() => {
|
|
||||||
resolve({});
|
|
||||||
}, 100);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
columns: [
|
|
||||||
{ type: "checkbox", width: 50 },
|
|
||||||
{ type: "seq", width: 60 },
|
|
||||||
{ field: "name", title: "Name", editRender: { name: "input" } },
|
|
||||||
{ field: "nickname", title: "Nickname", editRender: { name: "input" } },
|
|
||||||
{ field: "role", title: "Role", editRender: { name: "input" } },
|
|
||||||
{
|
|
||||||
field: "address",
|
|
||||||
title: "Address",
|
|
||||||
showOverflow: true,
|
|
||||||
editRender: { name: "input" }
|
|
||||||
}
|
|
||||||
]
|
|
||||||
} as VxeGridProps);
|
|
||||||
|
|
||||||
return {
|
|
||||||
gridOptions
|
|
||||||
};
|
|
||||||
}
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style scoped></style>
|
|
||||||
|
@ -2,10 +2,10 @@
|
|||||||
"compilerOptions": {
|
"compilerOptions": {
|
||||||
"target": "esnext",
|
"target": "esnext",
|
||||||
"module": "esnext",
|
"module": "esnext",
|
||||||
|
"moduleResolution": "node",
|
||||||
"strict": false,
|
"strict": false,
|
||||||
"jsx": "preserve",
|
"jsx": "preserve",
|
||||||
"importHelpers": true,
|
"importHelpers": true,
|
||||||
"moduleResolution": "node",
|
|
||||||
"experimentalDecorators": true,
|
"experimentalDecorators": true,
|
||||||
"strictFunctionTypes": false,
|
"strictFunctionTypes": false,
|
||||||
"skipLibCheck": true,
|
"skipLibCheck": true,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user