手把手带你开发一个低代码可视化平台(二)
liuian 2025-06-18 22:20 3 浏览
前文回顾
我开源的商城零代码可视化搭建平台Mall-Cook受到大家喜爱,使我深受鼓励。本着授人以鱼不如授人以渔思想,在项目新建shelf分支,带大家从零开发一个自己的可视化搭建平台。
上一节我们:
- 介绍了可视化搭建的架构
- 详细讲解了可视化搭建的核心 - 一套规范
- 开发了一个搭建面板,包括物料的嵌套,物料的工具容器等。
物料JSON构建属性面板流水线
构建逻辑
今天我们来开发通过物料JSON构建数据面板的逻辑
我们以图片物料的生成的过程为例(内容过多,请放大图片观看),物料JSON解析为两块:
- 物料属性描述,用于生成属性表单面板
- 物料初始数据,生成物料深拷贝初始数据,并传入对应属性表单,可通过表单修改数据
物料JSON
每个物料JSON都是物料的身份证,记载了物料的详细信息。我们解析其中数据使用在:
- 物料模板列表 (使用物料初始数据)
- 生成物料属性表单面板 (使用物料属性描述)
{
"name": "图片", // 物料名称
"icon": "icon-image", // 物料图标
"fields": { // 物料属性
"imagePath": { // imagePath 属性
"label": "图片上传", // label
"type": "upload", // upload 类型
"value": "" // 值
},
"radius": { // radius 属性
"label": "图片圆角", // label
"type": "number", // number 类型
"value": 0 // 值
}
}
}
其中属性type定义了属性的类型,同时也选择了操作此属性所用的操作组件,我现在定义的基础类型如下:
开发实现
大家清楚逻辑后我们开始开发,实际开发主要分为:
- 实现物料JSON注册方法开发(初始化所有物料的属性描述、初始数据)
- 开发物料属性面板解析器开发
- 实现上述基础类型操作组件开发
物料JSON注册
开发逻辑我们把每个物料的JSON放在自己的包下。然后我就可以根据这个规则,利用require.context遍历custom-components包下文件,找到所有component.json进行物料注册
物料JSON注册方法实现:
/*
* 解析物料Schmea,注册各物料属性参数与初始值
*/
import Vue from 'vue'
// 调用注册物料
registerComponentsSchema()
// 注册物料方法
function registerComponentsSchema () {
// 获取custom-components包下所有component.json
const files = require.context('@/custom-components', true, /component.json$/)
// 物料属性描述对象 (使用object类型方便调用)
let fields = {}
// 物料初始化数据集合
let initializing = []
// 遍历component.json注册物料
files.keys().forEach(key => {
// 获取物料名
const [, name] = key.split('/')
let config = { component: name, ...files(key) }
// 添加物料属性描述
fields[name] = config.fields
// 添加物料初始数据
initializing.push(initDefaulValue(config))
})
// Vue原型上绑定物料属性描述对象,方便调用
Vue.prototype.$fields = fields
// Vue原型上绑定物料初始化数据集合,方便调用
Vue.prototype.$initializing = initializing
}
// 获取物料初始数据,默认过滤fields属性
function initDefaulValue (config) {
let { component, name, icon, fields } = config
let temp = { component, name, icon }
setDefaultValue(fields, temp)
return temp
}
// 递归设置各层级初始数据(会存在多层级复杂对象类型)
function setDefaultValue (fields, initializing) {
for (let key in fields) {
let { type, value, child } = fields[key]
if (type == 'object') {
initializing[key] = {}
child && setDefaultValue(fields[key].child, initializing[key])
} else {
initializing[key] = value
}
}
return initializing
}
通过注册我们会获得:
- Vue.prototype.$fields (物料属性描述对象)
- Vue.prototype.$initializing(物料初始化数据集合)
属性面板解析器
开发逻辑
- 遍历属性描述对象,获取每个属性的label、type等信息,然后渲染对应操作组件,生成属性表单。
- 传入物料数据,把value设到对应属性操作组件,即可通过操作属性表单进行修改
<template>
<ul>
<!-- 遍历物料属性描述对象 -->
<li v-for="(s, key, index) in schema" :key="index">
<!-- 根据属性类型,渲染对应的操作组件 -->
<component
:key="index"
:is="getComponents(s.type)"
v-model="value[key]"
v-bind="s"
:schema="s"
>
<!-- 递归组件 -->
<custom-schema-template
v-if="s.child"
:schema="s.child"
:value="value[key]"
></custom-schema-template>
</component>
</li>
</ul>
</template>
<script>
export default {
name: 'custom-schema-template',
provide () {
return {
mode: this
}
},
props: {
schema: { // 物料属性描述对象
typeof: Object,
default: () => {}
},
value: { // 物料数据
typeof: Object,
default: () => {}
}
},
methods: {
// 获取对应类型的操作组件名,组件名定义为:schema-类型
// 例: input类型 -> schema-input
getComponents(type){
return `schema-${type}`
}
}
}
</script>
细心的同学会发现,属性面板解析器也是递归嵌套组件。这是因为属性类型除了基础类型外还存在复合类型,比如对象、对象数组等。复合类型会在下一节具体讲解。
基础类型操作组件
最后就是开发下图的基础类型操作组件,这块开发比较简单,我们任意举个栗子
sting类型 -> SchemaString组件
<template>
<config-item :label='label'>
<!-- input组件 -->
<el-input
v-model="mValue"
v-bind="mOptions"
:placeholder='mOptions.placeholder'
size='small'
></el-input>
</config-item>
</template>
<script>
import schemaMixin from "@/mixin/schemaMixin";
export default {
name: "SchemaString",
// 使用mixin,混入公用代码
mixins: [schemaMixin],
};
</script>
结尾
下一节预告
- 开发兼容物料属性复杂类型
- 开发JsonSchema生成器,可视化生成物料属性描述JSON
相关推荐
- vue是什么东西(vue是干什么的)
-
首先看看官方网站是怎么解释的,如下:Vue(读作/vju/,类似于view)是一个用于构建用户界面的渐进式框架。与其他单体框架不同,Vue从一开始就被设计为可逐步采用的。核心库仅专注于视图层,易于...
- 超赞 vue2/3 可视化打印设计VuePluginPrint
-
今天来给大家推荐一款非常不错的Vue可拖拽打印设计器Hiprint。引入使用//main.js中引入安装import{hiPrintPlugin}from'vue-plugin-...
- 使用VuePress2.X构建个人知识博客,域名部署到GitHub Pages中
-
使用VuePress2.X构建个人知识博客,并且用个人域名部署到GitHubPages中什么是VuePressVuePress是一个以Markdown为中心的静态网站生成器。你可以使用Mar...
- 尤雨溪新品Vite的魔力,详解(尤雨溪新品vite的魔力,详解解析)
-
上篇《尤雨溪是个恶魔,Vite三天10更》谈到了Webpack这一系列打包工具出现的原因。这些工具的出现是为了解决ESModules模块系统本身的环境兼容问题、以及零散的模块文件导致的...
- 什么是VUE?vue有什么作用?(vue的主要用途)
-
什么是vue?Vue.js是一套构建用户界面的渐进式框架,Vue采用自下向上增量开发的设计,其核心库只关注视图层,易于上手,同时vue完全有能力驱动采用单文件组件和Vue生态系统支持的库开发的复...
- 10个Vue开发技巧「实践」(vue开发需要掌握哪些知识)
-
作者:WahFung转发链接:https://juejin.im/post/5e8a9b1ae51d45470720bdfa路由参数解耦一般在组件内使用路由参数,大多数人会这样做:exportdef...
- 刚搭好vuecli结果官网建议升级vite,于是就升级下
-
从vue-cli迁移到Vite进行迁移的主要原因是速度。Vite的开发服务器速度很快。因为它使用原生浏览器支持JavaScript模块,所以服务器启动时间是即时的。该方法还意味着无论应用程...
- 无所不能,将 Vue 渲染到嵌入式液晶屏
-
该文章转载自公众号@前端时刻,https://mp.weixin.qq.com/s/WDHW36zhfNFVFVv4jO2vrA前言之前看了雪碧大佬的将React渲染到嵌入式液晶屏觉得很有意思,R...
- 【开源】基于 Vue 和 Gin 开发的前后端分离的开源框架
-
项目介绍Gin-vue-admin是一个基于vue和gin开发的全栈前后端分离的开发基础平台,旨在快速搭建中小型项目。拥有jwt鉴权,动态路由,动态菜单,casbin鉴权,表单生成器,代码生成器等功能...
- Firefox正针对Vue.js进行优化,下版本响应速度将“显著提升”
-
IT之家9月7日消息,据Mozilla官方博客发文显示,Firefox浏览器正针对Vue.js进行优化,此前FireFox浏览器在面向Vue3时遇到了一些性能问题。▲图源...
- vue:生命周期钩子函数及顺序(vue3.0生命周期函数)
-
一、vue的钩子相关顺序Vue实例有一个完整的生命周期,在newVue()后,会初始化数据,如下://初始化的入口,各种初始化工作initMixin(Vue);//数据绑定的核心方法,包括常用...
- 使用 Pinia ORM 管理 Vue 中的状态
-
转载说明:原创不易,未经授权,谢绝任何形式的转载状态管理是构建任何Web应用程序的重要组成部分。虽然Vue提供了管理简单状态的技术,但随着应用程序复杂性的增加,处理状态可能变得更具挑战性。这就是为什么...
- 搭建Trae+Vue3的AI开发环境(vue ide 开发工具)
-
从2024年2025年,不断的有各种AI工具会在自媒体中火起来,号称各种效率王炸,而在AI是否会替代打工人的话题中,程序员又首当其冲。作为一个后端开发,这篇文章基于Trae工具,来创建和运行一个简单的...
- 如何在Vue3中使用Nuxt进行服务端渲染开发?
-
服务端渲染SSR(Server-SideRendering)是一种在服务器端生成网页内容的技术,这种实现方式与传统的客户端渲染CSR(Client-SideRendering)有所不同。在SSR中...
- 一篇文章说清 webpack、vite、vue-cli、create-vue 的区别
-
webpack、vite、vue-cli、create-vue这些都是什么?看着有点晕,不要怕,我们一起来分辨一下。先看这个表格:脚手架vue-clicreate-vue构建项目vite打包代码we...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
python使用fitz模块提取pdf中的图片
-
《人人译客》如何规划你的移动电商网站(2)
-
Jupyterhub安装教程 jupyter怎么安装包
-
- 最近发表
-
- vue是什么东西(vue是干什么的)
- 超赞 vue2/3 可视化打印设计VuePluginPrint
- 使用VuePress2.X构建个人知识博客,域名部署到GitHub Pages中
- 尤雨溪新品Vite的魔力,详解(尤雨溪新品vite的魔力,详解解析)
- 什么是VUE?vue有什么作用?(vue的主要用途)
- 10个Vue开发技巧「实践」(vue开发需要掌握哪些知识)
- 刚搭好vuecli结果官网建议升级vite,于是就升级下
- 无所不能,将 Vue 渲染到嵌入式液晶屏
- 【开源】基于 Vue 和 Gin 开发的前后端分离的开源框架
- Firefox正针对Vue.js进行优化,下版本响应速度将“显著提升”
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- table.render (33)
- uniapp textarea (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)