基于 ElementUI 开发的可视化表单设计工具

《开源精选》是我们分享Github、Gitee等开源社区中优质项目的栏目,包括技术、学习、实用与各种有趣的内容。本期推荐的是一个基于vue-ele-form的表单设计器——f-render。

基于 ElementUI 开发的可视化表单设计工具

f-render 是基于element-ui form的二次封装,实现了表单校检、表单布局、响应式表单,并内置了单选,多选,级联等20 多款常用组件,并且有丰富的第三方组件(各种输入框、日期选择器、颜色选择器、级联选择器等) ,这一切的一切只需要拖拽组件即可实现,既保证了质量,又使得开发速度仿佛坐上火箭。

表单设计器

界面

基于 ElementUI 开发的可视化表单设计工具

拖拽控件

基于 ElementUI 开发的可视化表单设计工具

预览

基于 ElementUI 开发的可视化表单设计工具

生成代码

f-render方式:

基于 ElementUI 开发的可视化表单设计工具

vue-ele-form方式:

安装使用

安装

yarn add element-ui  # npm install element-ui -S
yarn add vue-ele-form # npm install vue-ele-form -S
yarn add f-render # npm install f-render -S

注册

// vue-ele-form 的注册可参考:https://www.yuque.com/chaojie-vjiel/vbwzgu/xl46cd
import EleForm from "vue-ele-form";
import FRender from "f-render";
import ElementUI from "element-ui";
import "element-ui/lib/theme-chalk/index.css";

Vue.use(ElementUI);
Vue.use(EleForm);
Vue.component("f-render", FRender);

使用

<template>
  <f-render
    @save="handleSave"
    :loading="loading"
    height="calc(100vh - 60px)"
    :config="formConfig"
  />
</template>

<script>
  export default {
    data() {
      return {
        loading: false,
        formConfig: {}
      };
    },
    methods: {
      handleSave(res) {
        // 这里是保存到 localStorage,你可以保存到服务器
        localStorage.setItem("form-config", res);
        this.$message.success("保存成功啦~");
      }
    },
    mounted() {
      // 模拟异步加载
      this.loading = true;
      setTimeout(() => {
        this.loading = false;
        this.formConfig = localStorage.getItem("form-config") || "";
      }, 1000);
    }
  };
</script>


—END—

开源协议:MIT

开源地址:https://gitee.com/dream2023/f-render

原文始发于微信公众号(开源技术专栏):基于 ElementUI 开发的可视化表单设计工具

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/53828.html

(0)
小半的头像小半

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!