A vue component for dynamic form create、dynamic table .
-
本项目适合 Vue3 ElementUI 下进行使用的,目前基础功能已经具备。
-
clone 后可以直接 npm install,然后 npm run start 即可开启 demo 查看。
-
根目录下的 index.js 为发布到 npmjs 使用的文件
-
根目录下的 main.js 为 npm run start 运行 demo 根据路由直接查看
npm install aehyok-form-vue3 -S
安装后根据用法一进行使用,如果有需要自己添加组件也已经预留组件入口
<template>
<div>
<el-row :gutter="20">
<el-col :span="12">
<el-form :model="formConfig.formData" label-width="120px" ref="refForm">
<FormView
:columnList="formConfig.formListItem"
:formData="formConfig.formData"
:columnSpan="formConfig.cols"
/>
</el-form>
</el-col>
<el-col :span="12">
<v-jsoneditor
v-model="formConfig"
:options="options"
:plus="false"
height="800px"
/>
</el-col>
</el-row>
<el-row>
<el-button
size="large"
type="primary"
style="margin-left: 120px;height: 50px;"
@click="submitForm"
native-type="submit"
>
提交
</el-button>
</el-row>
</div>
</template>
<script>
import FormView from 'aehyok-form'
import { getContentTypeList } from '@/mock/api'
import VJsoneditor from 'v-jsoneditor'
export default {
components: {
FormView,
VJsoneditor,
},
created() {
getContentTypeList().then(res => {
console.log(res.data, 'res.data.form')
})
// this.value=
},
methods: {
submitForm() {
this.$refs.refForm.validate(valid => {
if (valid) {
console.log(valid, 'this.valid')
} else {
console.log(valid, '验证失败')
}
return false
})
},
},
data() {
return {
options: { mode: 'code', mainMenuBar: false },
formConfig: {
cols: 24,
formListItem: [
{
name: 'name1',
type: 'text',
title: '栏目标题',
required: true, // 必填
},
{
name: 'total',
type: 'number',
title: '栏目数量',
required: true,
},
{
name: 'count',
type: 'number',
title: '浏览数量',
},
{
name: 'descript',
type: 'textarea',
title: '备注',
required: true,
},
{
name: 'startDate',
type: 'date',
title: '开始日期',
required: true,
},
{
name: 'isExpired',
type: 'switch',
title: '是否过期',
required: true,
},
{
name: 'type',
type: 'radio',
title: '栏目类型',
controls: [
{
value: 1,
showCondition: [
{
name: 'show',
type: 'radio',
title: '测试类型',
required: true,
}
],
},
{
value: 2,
showCondition: [
{
name: 'isValids',
type: 'switch',
title: '是否有效',
},
],
},
],
},
{
name: 'requireType',
type: 'radio',
title: '图文类型',
required: true,
},
{
name: 'range',
type: 'checkbox',
title: '发布范围',
required: true,
},
{
name: 'dateRange',
type: 'daterange',
title: '日期范围',
},
{
name: 'creType',
type: 'select',
title: '证件类型',
},
{
name: 'image',
type: 'image',
title: '头像',
},
],
formData: {
name: '主菜单栏目',
total: null,
count: null,
createDate: 1606730360386,
type: 1,
requireType: undefined,
creType: '',
range: [],
isExpired: false,
isValid: true,
},
},
}
},
}
</script>
<style scoped></style>
直接 clone 本仓库,然后将对应文件夹的代码(src/components/input)拷贝到自己的项目中
import FormView from "./components/input/formView";
剩余用法跟用法一一致;