基于vue-element-ui的一款表格设计器table-making

   日期:2020-07-08     浏览:1110    评论:0    
核心提示:简介如果你的项目中有很多的表格,即使用elment-ui table插件你也必须每次都必须写一遍代码进行开发,如果你使用过表单设计器,你就会希望能得到一款像form表单设计器一样可以通过拖拽配置快速生成一个表格,table-making就是一款不错的表格设计器。参照form-making的源码,并可以集成进form-making中配合表单或其他可视化工具中使用快速设计出表格,并且可以在vue项目中渲染。该插件包含两个重要组件TableMaking 表格设计器GenerateTable 表格渲染器g

简介

如果你的项目中有很多的表格,即使用element-ui table插件你也必须每次都必须写一遍代码进行开发,如果你使用过表单设计器,你就会希望能得到一款像form表单设计器一样可以通过拖拽配置快速生成一个表格,table-making就是一款不错的表格设计器。参照form-making的源码,并可以集成进form-making中配合表单或其他可视化工具中使用快速设计出表格,并且可以在vue项目中渲染。
该插件包含两个重要组件
TableMaking 表格设计器
GenerateTable 表格渲染器

gitHub地址

table-making

演示地址

table-making

使用教程

安装

npm install table-making

由于该项目使用了自定义代码编辑器monaco-editor,该工具打包后代码量稍大分割后有多个文件,项目中按需加载需要在引入该插件的工程中进行webpack配置 即在vue.config.js文件中增加如下插件CopyWebpackPlugin的配置(如何安装CopyWebpackPlugin及配置请自行学习)

    plugins: [
      new CopyWebpackPlugin(
      
        [
          {
            context: 'node_modules/table-making/dist/',
            from: '*.js',
            to: process.env.NODE_ENV === 'development' ? './':'static/js',
            toType: 'dir'
          },
          {
            context: 'node_modules/table-making/dist/',
            from: '*.css',
            to: process.env.NODE_ENV === 'development' ? './':'static/js',
            toType: 'dir'
          },
        ]
    )
  ]

项目中如何使用

完整引用

import TableMaking from 'table-making'
import 'table-making/dist/TableMaking.css'

Vue.use(TableMaking)

以上代码便完成了 TableMaking 的引入。需要注意的是,样式文件需要单独引入。

另外该项目实现了i18国际化如果你的项目也支持i18国际化,则请用一下方式引入组件,注意如果你的工程中有多个插件都支持国际化就必须在主工程中以以下方式引入

Vue.use(VueI18n)
const i18n = new VueI18n({
  locale: 'zh-CN', // 定义默认语言为中文 
  messages: { },//主工程的语言包,可以为空
});
//注册table-macking
Vue.use(TableMaking, { lang: 'zh-CN', locale: null, i18n: i18n})
//其他组件必须传入i18对象引入否则将会将上一个组件的语言包覆盖

引入部分组件

import {
  GenerateTable,
  MakingTable
} from 'table-making'
import 'table-making/dist/TableMaking.css'

Vue.component(GenerateTable.name, GenerateTable)
Vue.component(MakingTable.name, MakingTable)

引入 ace.js

如果你需要在设计器中预览表格,默认情况下没有引入ace.js,如果需要使用ace.js,需要自己引入

<!-- 需要在设计器中预览代码需要引入ace.js库 -->
<script src="https://unpkg.com/form-making/public/lib/ace/ace.js"></script>

页面中使用组件

1.设计器tabkeMaking的使用

    <fm-making-table v-show="activeName == 'config'" ref="makingtable" style=" min-height: calc(100vh - 100px);" preview generate-code generate-json>
      <template slot="action">
      </template>
    </fm-making-table>

效果

1.渲染器GenerateTable的使用

<template>
  <div>
    <fm-generate-form 
      :data="jsonData" 
      @on-change="onChange"
      :value="formData"
      ref="generateForm"
    >
    </fm-generate-form>
  </div>
</template>
<script>
export default {
  data () {
    return {
      jsonData: {
	  "list": [],
	  "config": {
	    "labelWidth": 100,
	    "labelPosition": "right",
	    "size": "small"
	  }
}
  },
  methods: {
    onChange (field, value) {
      if (field == 'name') {
        this.formData.show = value
      }
    }
  }
}
</script>

jsonData 数据即是上一步表格设计器生成的数据

效果

关于组件详细使用教程持续更新中

 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服