【form-generator在线表单生成---vue父组件调用vue弹框组件】

简介: 【form-generator在线表单生成---vue父组件调用vue弹框组件】

Element

UI表单设计及代码生成器,可将生成的代码直接运行在基于Element的vue项目中;也可导出JSON表单,使用配套的解析器将JSON解析成真实的表单。

1, form-generator

form-generator在线表单生成

https://mrhj.gitee.io/form-generator/#/

  • 左侧:供拖拽的组件
  • 中间:组件单个及组合预览效果
  • 右侧:组件及表达的配置项

2. 实现过程

  1. 把组件在config.js配置成json
  2. 通过拖拽把当前组件的json转化成vue render可以识别的数据格式
    那请问什么样的数据格式是vue render可以识别的?
    这个时候你就要了解下vue的render方法了~

3 render函数讲解

在使用render函数中,会使用到一个参数createElement,而这个createElement参数,本质上,也是一个函数,是vue中构建虚拟dom所使用的工具。下面就围绕着这个createElement来看一下。

在createelement方法,有三个参数:

  1. 第一个参数(必要参数):主要是用于提供dom中的html内容,类型可以是字符串、对象或函数。
  2. 第二个参数(对象类型,可选):用于设置这个dom中的一些样式、属性、传的组件的参数、绑定事件之类的。
  3. 第三个参数(类型是数组,数组元素类型是VNode,可选):主要用于设置分发的内容,如新增的其他组件。

注意:组件树中的所有vnode必须是唯一的 通过传入createElement参数,创建虚拟节点,然后再将节点返回给render返回出去。

总的来说,render函数的本质就是创建一个虚拟节点。

render方法了解的差不多了,那我们看下form-generator里面把json转化后的vnode

4,VUE 父组件调用子组件弹窗

4.1 父组件
<template>
    <div>
        <el-button @click="show">按钮</el-button>
        
        <!-- 新增编辑弹框子组件 -->
        <add-or-update :addOrUpdateVisible="addOrUpdateVisible" @changeShow="showAddOrUpdate" ref="addOrUpdateRef"></add-or-update>
    </div>
</template>
<script>
// 引入子组件
import AddOrUpdate from './Edit'
export default {
    data(){
        return{
            // 控制新增编辑弹窗的显示与隐藏
            addOrUpdateVisible: false
        }
    },
    // 使用子组件
    components:{
        AddOrUpdate
    },
    methods:{
        // 按钮点击事件 显示新增编辑弹窗组件
        show(){
            this.addOrUpdateVisible = true
        },
        // 监听 子组件弹窗关闭后触发,有子组件调用
        showAddOrUpdate(data){
            if(data === 'false'){
                this.addOrUpdateVisible = false
            }else{
                this.addOrUpdateVisible = true
            }
        }
    }
}
</script>
4.2 子组件
<template>
    <el-dialog
        title="提示"
        :visible.sync="showDialog"
        width="50%"
        @close="handleClose">
        <span>这是一段信息</span>
        <span slot="footer" class="dialog-footer">
            <el-button @click="showDialog = false">取 消</el-button>
            <el-button type="primary" @click="showDialog = false">确 定</el-button>
        </span>
    </el-dialog>
</template>
<script>
export default {    
    // 接受父组件传递的值
    props:{
        addOrUpdateVisible:{
            type: Boolean,         
            default: false
        }
    },
    data(){
        return{
            // 控制弹出框显示隐藏
            showDialog:false
        }
    },
    methods:{
        // 弹出框关闭后触发
        handleClose(){
            // 子组件调用父组件方法,并传递参数
            this.$emit('changeShow','false')
        }
    },
    watch:{
        // 监听 addOrUpdateVisible 改变
        addOrUpdateVisible(oldVal,newVal){
            this.showDialog = this.addOrUpdateVisible
        },
    }
}
</script>
<style lang="less" scoped>
</style>

5,参考

Element UI表单设计及代码生成器,可将生成的代码直接运行在基于Element的vue项目中;也可导出JSON表单,使用配套的解析器将JSON解析成真实的表单。

JSON解析器

将保存在数据库中的JSON表单,解析成真实的表单

// 安装
npm i form-gen-parser

vscode插件

帮助使用element UI的开发者完成基本的表单代码搭建任务,减少重复的劳动。

vscode-plugin分支配套插件为:form-generator-plugin;

使用插件可右键打开设计器,直接将代码保存到工程中。

安装插件请在vscode中搜索:

jakHuang

Form Generator Plugin

运行

确保已经安装node.js 10+

首次下载项目后,安装项目依赖:

yarn
npm install
//本地开发
npm run dev
//构建
npm run build

友情链接

vue-admin-beautiful —— 企业级、通用型中后台前端解决方案(基于vue/cli 4 最新版,同时支持电脑,手机,平板)

vue-admin-beautiful —— 在线演示

pl-table —— 完美解决 element 万级表格数据渲染卡顿问题

go-admin…

目录
相关文章
|
21小时前
|
监控 JavaScript
Vue中的数据变化监控与响应——深入理解Watchers
Vue中的数据变化监控与响应——深入理解Watchers
|
1天前
|
JavaScript 安全 前端开发
Vue 项目中的权限管理:让页面也学会说“你无权访问!
Vue 项目中的权限管理:让页面也学会说“你无权访问!
10 3
|
1天前
|
JavaScript 前端开发 开发者
Vue的神奇解锁:冒险的开始
Vue的神奇解锁:冒险的开始
5 1
|
1天前
|
JavaScript 前端开发
【vue】iview如何把input输入框和点击输入框之后的边框去掉
【vue】iview如何把input输入框和点击输入框之后的边框去掉
7 0
|
3天前
|
资源调度 JavaScript 前端开发
Vue的路由管理:VueRouter的配置和使用
【4月更文挑战第24天】VueRouter是Vue.js的官方路由管理器,用于在单页面应用中管理URL路径与组件的映射。通过安装并引入VueRouter,设置路由规则和创建router实例,可以实现不同路径下显示不同组件。主要组件包括:`&lt;router-link&gt;`用于创建导航链接,`&lt;router-view&gt;`负责渲染当前路由对应的组件。此外,VueRouter还支持编程式导航和各种高级特性,如嵌套路由、路由参数和守卫,以应对复杂路由场景。
|
1天前
|
JavaScript
【vue实战】父子组件互相传值
【vue实战】父子组件互相传值
7 1
|
2天前
|
JavaScript
vue2_引入Ant design vue
vue2_引入Ant design vue
6 0
|
2天前
|
JavaScript
vue知识点
vue知识点
10 4
|
2天前
|
存储 JavaScript 前端开发
【Vue】绝了!这生命周期流程真...
【Vue】绝了!这生命周期流程真...
|
3天前
|
JavaScript 索引
【vue】框架搭建
【vue】框架搭建
7 1