快速开始
基于 Ant Design Vue
部分组件的封装和扩展,提供更适配桌面端的高阶组件
安装
=> 适配支持 Ant Design Vue 4.x
bash
pnpm add @antd-templater/library-3.x@^4.3.21
pnpm add @antd-templater/eslint-config@^1.0.7
=> 适配支持 Ant Design Vue 3.x
bash
pnpm add @antd-templater/library-3.x@^3.0.2
如何使用
全局注册使用
typescript
import App from "./App.vue"
import AntdComponentPlugin from "@antd-templater/library-3.x"
createApp(App)
.use(AntdComponentPlugin)
.mount("#app")
vue
<template>
<section class="form-container">
<SForm
v-model="model"
:groups="groups"
/>
</section>
</template>
<script setup lang="ts">
import { formGroupsDefiner } from '@antd-templater/library-3.x'
defineOptions({
name: 'TestForm',
inheritAttrs: false,
})
const model: Ref<any> = ref({})
const groups = formGroupsDefiner([
{
type: 'AInput',
slot: 'title',
field: 'title',
label: '名称',
props: {
placeholder: '请输入名称',
},
},
])
</script>
自动按需导入使用
typescript
/* in vite.config.ts */
import { defineConfig } from "vitest/config"
import { AntdLibraryResolver } from '@antd-templater/library-3.x/resolver'
import AutoComponents from "unplugin-vue-components/vite"
export default defineConfig(() => {
return {
plugins: [
AutoComponents({
resolvers: [
AntdLibraryResolver(),
],
}),
],
}
})
vue
<template>
<section class="form-container">
<SForm
v-model="model"
:groups="groups"
/>
</section>
</template>
<script setup lang="ts">
import { formGroupsDefiner } from '@antd-templater/library-3.x'
defineOptions({
name: 'TestForm',
inheritAttrs: false,
})
const model: Ref<any> = ref({})
const groups = formGroupsDefiner([
{
type: 'AInput',
slot: 'title',
field: 'title',
label: '名称',
props: {
placeholder: '请输入名称',
},
},
])
</script>
手动按需导入使用
vue
<template>
<section class="form-container">
<SForm
v-model="model"
:groups="groups"
/>
</section>
</template>
<script setup lang="ts">
import { SForm } from '@antd-templater/library-3.x'
import { formGroupsDefiner } from '@antd-templater/library-3.x'
defineOptions({
name: 'TestForm',
inheritAttrs: false,
})
const model: Ref<any> = ref({})
const groups = formGroupsDefiner([
{
type: 'AInput',
slot: 'title',
field: 'title',
label: '名称',
props: {
placeholder: '请输入名称',
},
},
])
</script>
提示和辅助 Definer
在 SForm 范例 中,我们为了在定义 groups
时有良好的 TS 支持和提示,手动导入并使用 formGroupsDefiner
辅助。但能否自动按需导入呢?答案是可以的,需要配置如下:
ESlint => @antd-templater/eslint-config
typescript
import eslint from "@eslint/js";
import tseslint from "typescript-eslint";
import vueParser from "vue-eslint-parser";
import pluginVue from "eslint-plugin-vue";
import stylistic from "@stylistic/eslint-plugin";
import templater from "@antd-templater/eslint-config";
const flatArray = (options) => {
return !Array.isArray(options) ? [options] : options;
};
export default tseslint.config({
extends: [
...flatArray(eslint.configs.recommended),
...flatArray(tseslint.configs.recommended),
...flatArray(stylistic.configs["recommended-flat"]),
...flatArray(pluginVue.configs["flat/recommended"]),
...flatArray(templater.configs["flat/recommended"]),
],
});
TypeScript => @antd-templater/library-3.x/globals
json
{
"compilerOptions": {
"target": "ESNext",
"module": "ESNext",
"moduleResolution": "Bundler",
"types": ["@antd-templater/library-3.x/globals"]
}
}
unplugin-auto-import => @antd-templater/library-3.x/resolver
(only v4.x+)
typescript
/* Can automatically import Definder. eg: formGroupsDefiner */
import { defineConfig } from "vitest/config";
import { AntdLibraryResolver } from "@antd-templater/library-3.x/resolver";
import AutoImport from "unplugin-auto-import/vite";
export default defineConfig(() => {
return {
plugins: [
AutoImport({
resolvers: [AntdLibraryResolver()],
eslintrc: {
enabled: true,
filepath: "./.eslintrc-auto-import.json",
globalsPropValue: true,
},
dts: true,
}),
],
};
});
提供哪些 Definer?
@antd-templater/library-3.x
(only v4.x+)
md
- tableSorterDefiner
- tableScrollDefiner
- tableStickyDefiner
- tableSourcesDefiner
- tableSummarysDefiner
- tableColumnsDefiner
- tablePaginateDefiner
- tableLoadDataDefiner
- tableResponserDefiner
- tableEmitSorterDefiner
- tableEmitSelectDefiner
- tableEmitExpandDefiner
- tableEmitPageChangeDefiner
- tableEmitPageSizeChangeDefiner
- tableCustomHeaderRowAttrsDefiner
- tableCustomBodyerRowAttrsDefiner
- tableCustomFooterRowAttrsDefiner
- tableCustomBodyerRowStatesDefiner
- tableCustomHeaderCellRenderDefiner
- tableCustomBodyerCellRenderDefiner
- tableCustomFooterCellRenderDefiner
md
- treeDataDefiner
- treeLoadDataDefiner
- treeEmitCheckDefiner
- treeEmitSelectDefiner
- treeEmitExpandDefiner
- treeEmitChangeDefiner
- treeDropHandlerDefiner
- treeFieldNamesDefiner
md
- formValidator
- formGridDefiner
- formRulesDefiner
- formGroupsDefiner
md
- iconOptionsDefiner
浏览器兼容性
IE | Edge | Firefox | Chrome | Safari | Electron |
---|---|---|---|---|---|
不支持 | 支持 | 支持 | 支持 | 支持 | 支持 |