form-create 2.0發佈了!輕鬆搞定表單,不在爲表單煩惱

介紹

form-create 是一個能夠經過 JSON 生成具備動態渲染、數據收集、驗證和提交功能的表單生成器。而且支持生成任何 Vue 組件。結合內置17種經常使用表單組件和自定義組件,再複雜的表單均可以輕鬆搞定。html

文檔 | githubgit

功能

  • 自定義組件github

    • 可生成任何Vue組件
    • 自帶數據驗證
    • 輕鬆轉換爲表單組件
  • 經過 JSON 生成表單npm

  • 經過 Maker 生成表單element-ui

  • 強大的API,可快速操做表單bash

  • 雙向數據綁定app

  • 事件擴展iview

  • 局部更新工具

  • 數據驗證佈局

  • 柵格佈局

  • 內置組件17種經常使用表單組件

對比 1.x

  • 速度更快

  • 體積更小

  • 更強大的全局配置

  • 自定義組件更容易擴展

  • 更容易支持第三方 UI 庫

  • 更少的 bug

示例

經過 JSON 建立表單

https://user-gold-cdn.xitu.io/2019/6/23/16b83f253c61e404?w=964&h=615&f=gif&s=641193

經過 API 操做表單

https://user-gold-cdn.xitu.io/2019/6/23/16b83f2d4ca94d45?w=1452&h=539&f=gif&s=488039

@form-create包說明

名稱 說明
@form-create/iview iview 版表單生成器
@form-create/element-ui element-ui 版表單生成器
@form-create/core form-create 核心包
@form-create/utils form-create 工具包
@form-create/data 省市區多級聯動數據

使用

以element-ui版本爲例介紹如何在項目中使用 form-create

安裝

npm i @form-create/element-ui
複製代碼

掛載

全局註冊

import formCreate form '@form-create/element-ui';

Vue.use(formCreate);
複製代碼

局部掛載

import formCreate form '@form-create/element-ui';

export default {
    components:{
        formCreate:formCreaet.$form()
    }
}
複製代碼

生成表單

<template>
    <form-create v-model="$f" :rule="rule" @on-submit="onSubmit"></form-create>
</template>
複製代碼
export default {
  data () {
    return {
     //表單實例對象
     $f:{},
     //表單生成規則
     rule:[
       {
          type:'input',
          field:'goods_name',
          title:'商品名稱'
        },
        {
          type:'datePicker',
          field:'created_at',
          title:'建立時間'
        }
     ]
    };
  },
  methods:{
      onSubmit(formData){
          //TODO 提交表單
      }
  }
};
複製代碼

效果

form-create 效果圖

實例對象 $f

能夠經過 $f 快速操做表單,例如:

  • $f.hidden:隱藏指定組件
  • $f.validate:驗證表單
  • $f.setValue:修改表單組件的值
  • $f.append:追加表單組件

自定義組件

生成

經過標籤生成

{
    type:'el-button',
    name: 'btn',
    props:{
    	type:'primary',
    	field:'btn',
    	loading:true
    },
    children:['加載中']
}
複製代碼

經過模板生成

{
    type:'template',
    name:'btn'
    template:'<el-button :loading="loading">{{text}}<el-button>',
    vm: new Vue({
      data:{
        loading:true,
        text:'加載中'
      }
    })
}
複製代碼

轉換爲表單組件

自定義組件轉換爲表單組件後,可經過$f.formData,$f.getValue,$f.setValue,$f.disabled等方法快速操做組件,達到和內置組件相同的效果

預約義

props

在自定義組件內部經過props接收一下屬性

  • value 表單的值
  • disabled 組件的禁用狀態

例如:

vm = Vue({
  props:{
   value:String,
   disabled:Boolean      
  }
})
複製代碼

input 事件

經過input事件更新組件內部的值

當組件值發生變化後,經過 input 事件更新值.例如:

vm.$emit('input',newValue);
複製代碼

掛載自定義組件

要生成的自定義組件必須經過Vue.component方法掛載到全局,或者經過formCreate.component方法掛載

例如:

formCreate.component('TestComponent',component);
複製代碼

或者

Vue.component('TestComponent',component);
複製代碼

生成

表單組件必須定義field屬性

JSON

{
    type:'TestComponent',
    value:'test',
    field:'testField',
    title:'自定義組件'
}
複製代碼

Maker

formCreate.maker.create('TestComponent','testField','自定義組件').value('test')
複製代碼

示例

自定義計數器按鈕組件,獲取按鈕點擊數.該組件的功能和內置組件相同

formCreate.maker.template('<el-button @click="onClick" long :disabled="disabled">計數器-{{num}}</el-button>', new Vue({
  props:{
    //預約義
    disabled:Boolean,
    value:Number,
  },
  data: function () {
    return {
        num: this.value,
    }
  },
  watch:{
    value(n){
        this.num = n;
    }
  },
  methods: {
    onClick: function () {
        this.num++;
        //更新組件內部的值
        this.$emit('input',this.num);
    },
  },
}), 'tmp', '自定義 title').value(100).props('disabled',false)
複製代碼

完整示例

form-create示例.png
相關文章
相關標籤/搜索