vue+ant-design+formBuiler表单构建器——技能提升——form design——亲测有效

发布于:2024-05-09 ⋅ 阅读:(76) ⋅ 点赞:(0)

最近看到后端同事在弄一个后台管理系统,额,前端真的是夹缝中生存啊,AI抢饭碗,后端也想干前端的活儿。。。

他用到了表单构建器,具体效果如下:
在这里插入图片描述
网上有很多适用于ElementUiant-designform design插件,下面介绍一套完整的适用于ant-design的使用方法

步骤1:form-builder组件封装

components中添加form-builder文件夹
文件夹内容如下:
在这里插入图片描述
稍后我会把整个文件夹压缩上传到资源中,有需要的可自行下载。

步骤2:在页面中使用

我这边是在个弹窗中使用的,所以需要在弹窗中引入

<template>
  <a-modal
    width="100%"
    :title="title"
    :visible="visible"
    :confirm-loading="confirmLoading"
    :footer="null"
    @cancel="handleCancel"
  >
    <div style="height: 600px;overflow-y:auto;">
      <FormBuilder v-model="data" :gateway="gateway" :userModel="{}" @getData="saveData" />
    </div>
  </a-modal>
</template>

对应的script中的代码:

<script>
import FormBuilder from '@/components/form-builder/FormBuilder';
import { addProp, updateProp, getPropDetail } from '@/services/project/propTemplate';//这个是接口,具体得让后端同事处理了。
export default {
  components: {
    FormBuilder
  },
  data() {
    return {
      title: '新增属性',
      visible: false,
      confirmLoading: false,
      data: {
        propName: '',
        list: [],
        config: {}
      },
      gateway: this.$store.state.setting.gateway,//gateway: "http://192.168.16.100:9001",也是后端同事提供
      templateId: '',
      id: ''
    }
  },
  methods: {
    showModal(templateId, record) {
      this.templateId = templateId;
      if (record) {
        this.title = '编辑属性';
        this.id = record.id;
        this.getDetail();
      } else {
        this.title = '新增属性';
        this.id = '';
        this.data = {
          propName: '',
          list: [],
          config: {}
        }
      }
      this.visible = true;
    },
    getDetail() {
      getPropDetail({
        propertyTemplateId: this.templateId,
        templateId: this.id
      })
        .then(res => {
          this.data = {
            propName: res.data.name,
            list: res.data.templateFiled && JSON.parse(res.data.templateFiled),
            config: res.data.templateText && JSON.parse(res.data.templateText)
          }
        })
    },
    saveData(v) {
      this.visible = false;
      if (this.id) {
        updateProp({
          propertyTemplateId: this.templateId,
          templateId: this.id,//模板属性id
        }, {
          name: v.propName,
          templateText: JSON.stringify(v.config),
          templateFiled: JSON.stringify(v.data)
        })
          .then(res => {
            this.$message.success('保存成功');
            this.$emit('ok');
          })
      } else {
        addProp(this.templateId, {
          name: v.propName,
          templateText: JSON.stringify(v.config),
          templateFiled: JSON.stringify(v.data)
        })
          .then(res => {
            this.$message.success('保存成功');
            this.$emit('ok');
          })
      }
    },
    handleCancel() {
      this.visible = false;
    }
  }
}
</script>

步骤3:步骤2弹窗的使用

import PropEdit from './PropEdit';
export default {
  components: {
    PropEdit
  },
}

页面使用

<a-button type="primary" @click="$refs.propEdit.showModal(templateId)">新增</a-button>
<PropEdit ref="propEdit" @ok="getPropList"></PropEdit>