IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> form-generator表单生成器使用总结~~ -> 正文阅读

[JavaScript知识库]form-generator表单生成器使用总结~~

表单设计器中开发自定义组件流程

  1. src\components\generator\config.js 中添加一个json
  2. src\compontnes\目录下创建对应的组件
  3. main.js中全局注册刚创建的组件
  4. src\views\index\RightPanel.vue 中绑定第一步中json中添加的各个属性值
详细步骤

步骤一: src\components\generator\config.js 中添加一个json

export const layoutComponents = [
    {
        __config__: {
          label: '自定义按钮',
          showLabel: false,
          changeTag: true,
          labelWidth: null,
          tag: 'wsButton',
          tagIcon: 'button',
          span: 24,
          layout: 'colFormItem',
        },
        __slot__: {
          default: '分享按钮111'
        },
        style: {
          width: 'auto',
          height: '35px',
          margin: '20px',
          borderRadius: '30px',
          display: 'flex',
          justifyContent: 'center',
          alignItems: 'center',
          color: '#FFF',
          backgroundColor: '#409EFF',
          borderColor: '#409EFF'
        },
        dataName: '测试分享按钮',
        type: 'primary',
        icon: '',
        round: false,
        size: 'normal',
        site: 'center', // 按钮位置 左:flex-start 中:cneter 右:flex-end
        plain: false,
        circle: false,
        disabled: false,
        funcType: 'share'
    }
]

注意点:

a. 在 __config__ 中的tag属性要注意和注册组件名称一致, render时候会拿这个tag去渲染

步骤二: src\compontnes\目录下创建对应的组件

eg: wsButton组件
    <template>
    ** 这里 ref一定要加 **
      <div ref="wsButton" class="wsButton" @click="handleShare">
        <div v-text="shareText"> 去分享 </div>
      </div>
    </template>
    
    <script>
    import { EventBus } from '@/utils/bus.js'
    import resetpx from '@/mixins/resetpx.js'
    export default {
      name: 'WsButton',
      data () {
        return {}
      },
      mixins: [resetpx], // 用来转化px为vw
      computed: {
        shareText () {
          return this.$attrs.dataName
        }
      },
      methods: {
        handleShare () {
          EventBus.$emit('openShare', 'wsButton')
        }
      }
    }
    </script>

注意点:

a. 通过监听$attrs可以拿到元素上的自定义属性值和style等;
b. 组件最后要复制到另一个渲染的项目里,复制过去之后要加上 resetpx 这个混入把元素的px转换为vw;
c. 组件可以用vant提供的或者自定义组件,但是不能用element-ui的一些组件;
d. 组件的最外层一定要加上 ref="组件名称"

步骤三: main.js中全局注册刚创建的组件

    import Vue from 'vue'
    import wsButton from '@/components/wsButton/index.vue'
    Vue.component('wsButton', wsButton)

步骤四: src\views\index\RightPanel.vue 中绑定第一步中json中添加的各个属性值

    <el-form-item
        v-if="activeData.__config__.tag === 'wsButton'"
        label="按钮标题"
      >
        <el-input
          v-model="activeData.dataName"
          placeholder="请输入按钮标题"
          @input="changeRenderKey"
        />
    </el-form-item>

表单设计器嵌入后台系统的数据交互

表单系统通过iframe的形式嵌入到后台管理系统中,通过postMessage进行数据交互

  1. 表单设计系统发送数据给后台管理系统
    <!--表单设计系统发送数据-->
    saveData() {
      const formConfData = {
        fields: deepClone(this.drawingList),
        ...this.formConf
      }
      window.parent.postMessage({
        source: 'formGenerator',
        data: formConfData
      }, '*')
    },
    
    <!-- 后台管理系统接收数据 -->
    mounted () {
        window.addEventListener('message', event => {
          if (event.data.source === 'formGenerator') {
            let formData = event.data.data
            this.fromConfData = formData
            localStorage.setItem('fromConfData', JSON.stringify(this.fromConfData))
          }
        }, '*')
    },
  1. 后台管理系统发送数据给表单设计系统
    <!-- 后台管理系统发送数据 -->
    openPreView () {
      let formData = localStorage.getItem('fromConfData')
      let child = this.$refs.child.contentWindow
      child.postMessage({
        source: 'formGenerator',
        data: formData
      }, '*');
    }
    
    <!-- 表单设计系统接收数据 -->
    mounted () {
        window.addEventListener('message', event => {
            console.log('后台系统发送的数据===', event)
        })
    }
    

渲染部分系统引入组件流程

设计器开发完组件后要把组件复制、注册到渲染系统中

具体步骤:
  1. 将组件复制到 src/components 目录下
  2. main.js中全局注册
    import wsButton from './components/wsButton'

    Vue.component('wsButton', wsButton)

  1. 在utils/global.js 中添加下组件的名称

这里添加是为了下一步中的px转化vw

    const allComponends = [
      'wsText',
      'wsButton',
      'wsImage' // 这里添加
    ]
    
    export {
      allComponends
    }
  1. 在组件的 mixins 中引入 resetpx 方法进行px单位的转换
    <script>
        import resetpx from '@/mixins/resetpx.js'
        export default {
          name: 'WsButton',
          data () {
            return {}
          },
          mixins: [resetpx] // 重置元素style里的px为vw
        }
    </script>

参考资料:

form-generator官方文档:点这里 => link

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-11-15 15:45:41  更:2021-11-15 15:46:25 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 11:02:44-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码