• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

ng-form-iview: 动态表单,VUE动态表单。基于vue+Iview实现动态表单组件,通过拖拽组 ...

原作者: [db:作者] 来自: 网络 收藏 邀请

开源软件名称:

ng-form-iview

开源软件地址:

https://gitee.com/jjxliu306/ng-form-iview

开源软件介绍:

NG-FORM-IVIEW 致力打造开源最强vue + iview动态表单组件

NG-FORM-IVIEW

组件一览

在线示例https://jjxliu306.github.io/ng-form-iview/dist

element-ui版本地址https://gitee.com/jjxliu306/ng-form-element

element-plus版本地址https://gitee.com/jjxliu306/ng-form-elementplus

后端服务

ngtool 后端解析和校验功能https://gitee.com/jjxliu306/ngtool

集成示例

基于springboot + vue 的前后端分离集成案例

后端springboot: https://gitee.com/jjxliu306/ng-server

前端vue: https://gitee.com/jjxliu306/ng-ui

##示例

基础表单基础表单

表单验证和组件动态显示表单验证和组件动态显示

动态表格动态表格

简介

基于vue和iview实现的表单设计器。通过拖拽方式快速生成一个表单页面,表单可以导出json格式,也可以将其他人绘制的表单通过json导入方式进行还原。

和其他开源表单的差异

  • 每个组件可以动态隐藏和显示,并且提供除了“必填”以外的多种规则验证,支持表达式验证和正则验证
  • 隐藏的组件绑定值可以配置不输出,减少输出数据大小
  • 针对选择性控件(radio,select,checkbox)提供选择后触发调用,支持表达式。对选择性控件支持数据联动功能,通过此功能可以做多级联动
  • 动态表格提供单独的弹框进行填写和编辑
  • 布局方式多样化,提供栅格,表格等多种布局方式
  • 支持表单预览模式,表单内容全部非组件化,全部文本显示
  • 针对选择性控件(radio,select,checkbox)选择后将对应的label进行单独存储,方便展示

组件

  • ng-form-design 表单设计器(基于可视化操作快速设计出表单页面,生成配置json或页面)
  • ng-form-build 表单构建器(根据设计器中获取的配置json数据,快速构建出表单页面,添加readonly属性后展现预览表单)

安装

npm install --save  ng-form-iview

引用

 // 导入组件库import NgFormIView  from 'ng-form-iview'import 'ng-form-iview/lib/ng-form-iview.css'

注册

// 注册组件库Vue.use(NgFormIView) 

页面引用

<div id="app">     <ng-form-design  /></div>

API 说明

1. 表单绘制组件 ng-form-design

方法:

方法名称参数说明
initModeljson初始化动态表单内容,参数为动态表单json模板
getModelN/A返回当前正在编辑得动态表单信息

属性:

属性名说明格式默认值
customComponents自定义组件的配置,具体参加最下方自定义组件示例中的格式arrayN/A
config表单的一些基础配置,主要为http的一些参数,譬如在http请求中给header增加参数:config: { httpConfig: (config)=>{ config.headers['aaaa'] = 'bbbb' return config } }objectN/A
clear是否显示面板上清除按钮booleantrue
preview是否显示面板上预览按钮booleantrue
reder是否显示面板上渲染按钮booleantrue
imp是否显示面板上导入按钮booleantrue
exp是否显示面板上导出按钮booleantrue
basic-item基础组件是否要展示或待选组件列表集合boolean/Arraytrue
personal-item个性化组件是否要展示或待选组件列表集合boolean/Arraytrue
layout-item布局组件是否要展示或待选组件列表集合boolean/Arraytrue

插槽:

插槽名称说明
drag左侧组件面板插槽,可以在组件面板上面填充一个区域展示内容
form-name当前动态表单名称
control-button功能区按钮,如果需要自定义功能按钮可以在这里自定义

插槽示例:

 <ng-form-design >       <template slot="controlButton" >           <el-button   type="text" size="medium"  @click="initDemo(1)">示例1</el-button>           <el-button   type="text" size="medium"  @click="initDemo(2)">示例2</el-button>           <el-button   type="text" size="medium"  @click="initDemo(3)">示例3</el-button>       </template>       <template  slot="formName">           <span> vue-drag-formdesign 示例 </span>       </template>   </ng-form-design> 

2. 表单查看/填报组件 ng-form-build

方法:

方法名称参数说明
resetN/A重置动态表单内容
validatorN/A根据设置的规则验证当前表单内容,返回Promise
getDataN/A表单验证后,获取当前表单数据,返回Promise

属性:

属性名说明格式默认值
formTemplate表单模板json
models表单填充数据json
disabled是否禁用booleanfalse
renderPreview当前是否为预览模式booleanfalse
config表单的一些基础配置,主要为http的一些参数,譬如在http请求中给header增加参数:config: { httpConfig: (config)=>{ config.headers['aaaa'] = 'bbbb' return config } }objectN/A
customComponents自定义组件的配置,具体参加最下方自定义组件示例中的格式arrayN/A

使用示例:

   <template>     <div id="app">         <ng-form-build  :formTemplate="formTemplate" :models="models"/>     </div>   </template>   <script>   export default {     data(){       return {         models: {} ,         formTemplate: {}       }     },     created() {       this.formTemplate = require('./data/basic.json')     }   }   </script>

3. 自定义组件示例

3.1 自定义一个组件(根据文本中输入的地址展示图片)

<template>  <div>     <el-input      v-if="!preview"      type="textarea"      autosize      placeholder="请输入图片地址"      v-model="models[record.model]" :disabled="disabled">    </el-input>      <el-image        :style="record.options.style ? record.options.style : null"        :src="models[record.model]"        fit="scale-down"></el-image>   </div> </template><script>  export default {     props: {          record: {//组件数据        type: Object,        required: true      },       models: {// 表单数组         type: Object,        required: true      },       disabled: { // 是否禁用        type: Boolean,        default: false      } ,       preview: {// 是否当前是预览        type: Boolean ,        default: false      }     },    methods: {     }  }</script>

3.2 定义一个自定义组件的属性配置组件(后面通过插槽挂到表单绘制面板的属性面板中)

<template>  <!-- 自定义组件的属性配置 -->    <el-form v-show="selectItem.key" size="mini" :disabled="disabled">    <!-- TCustom   start-->      <template v-if="selectItem.type == 'customT'">             <!-- 开关的label -->          <el-form-item   label="图片样式">              <el-input type="textarea" placeholder="请输入" v-model="selectItem.options.style" />           </el-form-item>      </template>       <!-- TCustom  end -->  </el-form> </template><script>export default {  props: {      selectItem: { // 当前选择的组件        type: Object,        required: true      },      disabled: { // 是否禁用        type: Boolean,        default: false      }  } }</script>

3.3 在动态表单绘制面板中进行配置

<template>  <div id="app">    <ng-form-design ref="formDesign" :custom-components="customComponents" >       <!-- 自定义属性配置 -->      <template slot="custom-properties" slot-scope="{selectItem}">        <Properties :selectItem="selectItem"/>      </template>       <template  slot="formName">        <span> vue-drag-formdesign 示例 </span>      </template>    </ng-form-design>     </div></template> <script>// 引用自定义的表单组件和自定义组件配置信息修改组件import CustomT from './components/TCustom'import Properties from './components/properties'export default {  name: 'App',  components: {CustomT , Properties},  data(){    return {        // 自定义组件列表      customComponents: [        {           type: 'customT' ,          label: "自定义图片展示", // 标题文字           component: CustomT ,          options: {            style: 'width:100px;height:100px'          },          model: "customT",          key: "customT",          rules: [            {              required: false,              message: "必填项"            }          ]        },      ]    }  } ,    methods: {   }}</script> 

交流

点击链接加入qq群聊,可以直接提问及反馈bug 【交流群:203205848】 vue-form-design


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap