# f-render **Repository Path**: hlx_coltd/f-render ## Basic Information - **Project Name**: f-render - **Description**: f-render | 基于 ElementUI 的表单设计器 - **Primary Language**: JavaScript - **License**: MIT - **Default Branch**: master - **Homepage**: https://dream2023.gitee.io/f-render - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 478 - **Created**: 2020-09-09 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # f-render | 基于 vue-ele-form 的表单设计器 [![MIT](https://img.shields.io/github/license/dream2023/f-render)](https://github.com/dream2023/f-render) ![npm bundle size](https://img.shields.io/bundlephobia/minzip/f-render) ![npm](https://img.shields.io/npm/dt/f-render) [![Netlify Status](https://api.netlify.com/api/v1/badges/4c2ddffb-26b2-4e64-8b22-25678db57483/deploy-status)](https://app.netlify.com/sites/f-render/deploys) ![gitub pages](https://github.com/dream2023/f-render/workflows/gitub%20pages/badge.svg) [![Star on GitHub](https://img.shields.io/github/stars/dream2023/f-render.svg?style=social)](https://github.com/dream2023/f-render/stargazers) - [交流群](#%E4%BA%A4%E6%B5%81%E7%BE%A4) - [介绍](#%E4%BB%8B%E7%BB%8D) - [注意](#%E6%B3%A8%E6%84%8F) - [特性](#%E7%89%B9%E6%80%A7) - [Demo](#demo) - [安装 & 注册](#%E5%AE%89%E8%A3%85--%E6%B3%A8%E5%86%8C) - [使用简介](#%E4%BD%BF%E7%94%A8%E7%AE%80%E4%BB%8B) - [表单设计](#%E8%A1%A8%E5%8D%95%E8%AE%BE%E8%AE%A1) - [表单使用](#%E8%A1%A8%E5%8D%95%E4%BD%BF%E7%94%A8) - [基于 f-render 使用](#%E5%9F%BA%E4%BA%8E-f-render-%E4%BD%BF%E7%94%A8) - [基于 vue-ele-form 使用](#%E5%9F%BA%E4%BA%8E-vue-ele-form-%E4%BD%BF%E7%94%A8) - [定制化](#%E5%AE%9A%E5%88%B6%E5%8C%96) - [新增官方扩展组件(以富文本扩展为例)](#%E6%96%B0%E5%A2%9E%E5%AE%98%E6%96%B9%E6%89%A9%E5%B1%95%E7%BB%84%E4%BB%B6%E4%BB%A5%E5%AF%8C%E6%96%87%E6%9C%AC%E6%89%A9%E5%B1%95%E4%B8%BA%E4%BE%8B) - [安装组件](#%E5%AE%89%E8%A3%85%E7%BB%84%E4%BB%B6) - [注册组件](#%E6%B3%A8%E5%86%8C%E7%BB%84%E4%BB%B6) - [配置属性](#%E9%85%8D%E7%BD%AE%E5%B1%9E%E6%80%A7) - [新增自定义组件](#%E6%96%B0%E5%A2%9E%E8%87%AA%E5%AE%9A%E4%B9%89%E7%BB%84%E4%BB%B6) - [创建组件并全局注册](#%E5%88%9B%E5%BB%BA%E7%BB%84%E4%BB%B6%E5%B9%B6%E5%85%A8%E5%B1%80%E6%B3%A8%E5%86%8C) - [书写配置](#%E4%B9%A6%E5%86%99%E9%85%8D%E7%BD%AE) - [合并配置并传入](#%E5%90%88%E5%B9%B6%E9%85%8D%E7%BD%AE%E5%B9%B6%E4%BC%A0%E5%85%A5) - [定制化原组件配置 & 表单配置](#%E5%AE%9A%E5%88%B6%E5%8C%96%E5%8E%9F%E7%BB%84%E4%BB%B6%E9%85%8D%E7%BD%AE--%E8%A1%A8%E5%8D%95%E9%85%8D%E7%BD%AE) - [样式定制化](#%E6%A0%B7%E5%BC%8F%E5%AE%9A%E5%88%B6%E5%8C%96) - [二次开发](#%E4%BA%8C%E6%AC%A1%E5%BC%80%E5%8F%91) - [f-render 不能做什么?](#f-render-%E4%B8%8D%E8%83%BD%E5%81%9A%E4%BB%80%E4%B9%88) - [Props 说明](#props-%E8%AF%B4%E6%98%8E) - [生态](#%E7%94%9F%E6%80%81) - [特别感谢赞助者](#%E7%89%B9%E5%88%AB%E6%84%9F%E8%B0%A2%E8%B5%9E%E5%8A%A9%E8%80%85) - [Contributors ✨](#contributors-) ## 交流群 ![交流群](https://i.loli.net/2020/02/07/MmY1u7f4wR3igcB.jpg) ## 介绍 f-render 是基于 [vue-ele-form](https://github.com/dream2023/vue-ele-form) 开发的可视化表单设计工具, 适用于 各种流程引擎和动态表单项目,大大节省你的开发时间; [![f-render 演示图](https://s1.ax1x.com/2020/08/23/d0T976.gif)](https://dream2023.gitee.io/f-render/) ## 注意 注意,此设计器不是独立存在的,是依托于 [vue-ele-form](https://github.com/dream2023/vue-ele-form),在使用前请务必阅读 [vue-ele-form 的文档](https://www.yuque.com/chaojie-vjiel/vbwzgu/xl46cd)。 ## 特性 - 组件方式:以组件方式接入,1 分钟轻松接入; - 体积小:Gzip 压缩后 `200k` 以内; - 易扩展:可以在`不更改源码`的情况下增删改属性、组件; ## Demo [https://dream2023.gitee.io/f-render/](https://dream2023.gitee.io/f-render/) ## 安装 & 注册 ```bash yarn add element-ui # npm install element-ui yarn add vue-ele-form # npm install vue-ele-form yarn add f-render # npm install f-render ``` ```js // 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); ``` ## 使用简介 使用分为两个部分,首先是进行表单拖拽设计,然后再已纯表单的形式使用 ### 表单设计 ```html ``` ### 表单使用 #### 基于 f-render 使用 通过属性 `pure`, 可以直接做为表单使用,其数据提交方式同 `vue-ele-form` 一样,具体可查看[文档](https://www.yuque.com/chaojie-vjiel/vbwzgu/zbu9mn)。 ```html ``` #### 基于 vue-ele-form 使用 如果你的可视化设计和表单使用,不再一个系统,可以直接使用 `vue-ele-form`,不必安装 `f-render`,具体如下: ```html ``` ## 定制化 ### 新增官方扩展组件(以富文本扩展为例) #### 安装组件 ```bash yarn add vue-ele-form-quill-editor ``` #### 注册组件 ```js Vue.component("quill-editor", EleFormQuillEditor); ``` #### 配置属性 ```html ``` ### 定制化原组件配置 & 表单配置 - 组件配置目录:`f-render/src/fixtures/comps.js` - 表单配置目录:`f-render/src/fixtures/form-props.js` - 表单项通用属性配置:`f-render/src/fixtures/form-item-common.js` - 扩展组件目录:`f-render/src/fixtures/extends/[扩展组件名].js` 如果你想修改组件属性或者表单的属性,减少或者增加组件,可以将上述文件`拷贝到自己的项目`目录,参考上述配置说明,进行更改,并传入即可: ```html ``` ### 样式定制化 直接进行样式覆盖即可,注意不要加 `scoped`,否则覆盖不成功 ## 二次开发 如果仅通过`属性`和`样式`定制化已无法满足的你和你产品经理的要求,那就需要进行定制化开发,我个人觉得代码整体还是非常简单的,你可以 `clone` 代码或者下载后(建议用[gitee](https://gitee.com/dream2023/f-render)),进行相应的更改,更改后有两种处理方式: - 直接放到项目目录里,并将安装 `dependencies` 的依赖复制到项目,进行开发即可; - 直接开发,然后发布到公司[私服](https://www.npmjs.com/package/verdaccio),如果是开源,则可以发到 GitHub 或者 gitee,然后安装自己的即可 如果你或者你的公司需要`付费`源码讲解和答疑,可加我微信:`dream10nian`。当然也有也有免费的交流群,也是加这个微信。 ## f-render 问答集锦 - [1、f-render 不能做什么?](https://www.yuque.com/chaojie-vjiel/vbwzgu/adz8q8#0nlfc) - [2、怎么实现 options URL 配置?](https://www.yuque.com/chaojie-vjiel/vbwzgu/adz8q8#gvS8c) ## Props 说明 ```js props: { // 表单内容 config: { type: [Object, String], required: true }, // 设计器整体高度 height: { type: [String, Number], default: "400px" }, // 保存格式 saveFormat: { type: String, default: "string", validator(val) { return ["object", "string"].includes(val); } }, // 是否纯净(用于显示表单) pure: Boolean, // 表单配置 formProps: { type: Object, default: () => formProps }, // 表单项配置 formItemCommon: { type: Object, default: () => formItemCommonDefault }, // 组件列表 comps: { type: Array, default: () => comps }, // 操作配置 operations: { type: Array, default: () => ["preview", "data", "code", "batch", "clear"] }, // 是否在加载 loading: Boolean, // 表单相关(pure 为 true 时), 同 vue-ele-form // https://www.yuque.com/chaojie-vjiel/vbwzgu/dyw8a7 requestFn: Function, isLoading: Boolean, formError: Object, // .... }, ``` ## 生态 | Project | Status | Description | | ----------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------ | | [vue-ele-form](https://github.com/dream2023/vue-ele-form) | [![npm](https://img.shields.io/npm/v/vue-ele-form)](https://github.com/dream2023/vue-ele-form) | 接基于 ElementUI 的数据驱动表单 | | [f-render](https://github.com/dream2023/f-render) | [![npm](https://img.shields.io/npm/v/f-render)](https://github.com/dream2023/f-render) | 专为 vue-ele-form 开发的可视化表单设计工具 | | [vue-ele-form-json-editor](https://github.com/dream2023/vue-ele-form-json-editor) | [![npm](https://img.shields.io/npm/v/vue-ele-form-json-editor)](https://github.com/dream2023/vue-ele-form-json-editor) | JSON 编辑器(vue-ele-form 扩展) | | [vue-ele-form-upload-file](https://github.com/dream2023/vue-ele-form-upload-file) | [![npm](https://img.shields.io/npm/v/vue-ele-form-upload-file)](https://github.com/dream2023/vue-ele-form-upload-file) | upload 文件上传组件(vue-ele-form 扩展) | | [vue-ele-form-image-uploader](https://github.com/dream2023/vue-ele-form-image-uploader) | [![npm](https://img.shields.io/npm/v/vue-ele-form-image-uploader)](https://github.com/dream2023/vue-ele-form-image-uploader) | 上传图片增强组件(vue-ele-form 扩展) | | [vue-ele-form-tree-select](https://github.com/dream2023/vue-ele-form-tree-select) | [![npm](https://img.shields.io/npm/v/vue-ele-form-tree-select)](https://github.com/dream2023/vue-ele-form-tree-select) | 树形选择框组件(vue-ele-form 扩展) | | [vue-ele-form-table-editor](https://github.com/dream2023/vue-ele-form-table-editor) | [![npm](https://img.shields.io/npm/v/vue-ele-form-table-editor)](https://github.com/dream2023/vue-ele-form-table-editor) | 表格编辑器(vue-ele-form 扩展) | | [vue-ele-form-dynamic](https://github.com/dream2023/vue-ele-form-dynamic) | [![npm](https://img.shields.io/npm/v/vue-ele-form-dynamic)](https://github.com/dream2023/vue-ele-form-dynamic) | 动态表单(vue-ele-form 扩展) | | [vue-ele-form-video-uploader](https://github.com/dream2023/vue-ele-form-video-uploader) | [![npm](https://img.shields.io/npm/v/vue-ele-form-video-uploader)](https://github.com/dream2023/vue-ele-form-video-uploader) | 上传视频增强组件(vue-ele-form 扩展) | | [vue-ele-form-quill-editor](https://github.com/dream2023/vue-ele-form-quill-editor) | [![npm](https://img.shields.io/npm/v/vue-ele-form-quill-editor)](https://github.com/dream2023/vue-ele-form-quill-editor) | 富文本编辑器(vue-ele-form 扩展) | | [vue-ele-form-markdown-editor](https://github.com/dream2023/vue-ele-form-markdown-editor) | [![npm](https://img.shields.io/npm/v/vue-ele-form-markdown-editor)](https://github.com/dream2023/vue-ele-form-markdown-editor) | markdown 编辑器(vue-ele-form 扩展) | | [vue-ele-form-bmap](https://github.com/dream2023/vue-ele-form-bmap) | [![npm](https://img.shields.io/npm/v/vue-ele-form-bmap)](https://github.com/dream2023/vue-ele-form-bmap) | 百度地图组件(vue-ele-form 扩展) | | [vue-ele-form-codemirror](https://github.com/dream2023/vue-ele-form-codemirror) | [![npm](https://img.shields.io/npm/v/vue-ele-form-codemirror)](https://github.com/dream2023/vue-ele-form-codemirror) | 代码编辑器(vue-ele-form-gallery 扩展) | | [vue-ele-form-gallery](https://github.com/dream2023/vue-ele-form-gallery) | [![npm](https://img.shields.io/npm/v/vue-ele-form-gallery)](https://github.com/dream2023/vue-ele-form-gallery) | 图片/视频展示组件(vue-ele-form 扩展) | | [vue-ele-form-data-editor](https://github.com/dream2023/vue-ele-form-data-editor) | [![npm](https://img.shields.io/npm/v/vue-ele-form-data-editor)](https://github.com/dream2023/vue-ele-form-data-editor) | 轻量级数据编辑器(vue-ele-form 扩展) |

特别感谢赞助者

优客服
圣捷远创
damonnie
xzusoft
seeenter
高亢
> 如果您觉得对您有所帮助, 可以请作者喝一杯咖啡, 让开源走的更远, 点击进入[码云赞赏](https://gitee.com/dream2023/f-render)一下, 并加入下面交流群, 将链接发送给我 ## Contributors ✨ Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):

张超杰

📖 💻 🤔

Wisen

💻

IWANABETHATGUY

💻
This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!