您好!
欢迎来到京东云开发者社区
登录
首页
博文
课程
大赛
工具
用户中心
开源
首页
博文
课程
大赛
工具
开源
更多
用户中心
开发者社区
>
博文
>
飞码LowCode前端技术(七)
分享
打开微信扫码分享
点击前往QQ分享
点击前往微博分享
点击复制链接
飞码LowCode前端技术(七)
灰豆****
2023-10-16
IP归属:北京
124浏览
(飞码画布设计) 作者:王光辉 部门:京东科技-市场与平台运营中心-营销与数据资产部-营销及数据平台研发部 ## 简介 飞码是京东科技-市场与平台运营中心-平台研发部研发低代码产品,可使营销运营域下web页面快速搭建。飞码是单web页面搭建工具,从创建页面到监测再到投产的一站式解决方案。会通过七篇文章介绍飞码,分别是:(1)、背景与数据结构设计,(2)、如何便捷配置出页面-1,(3)、如何便捷配置出页面-2,(4)、如何便捷配置出页面-3,(5)、如何便捷配置出页面-4,(6)、如何便捷快速验证实现投产及飞码探索,**(7)、飞码画布的设计**。 本章节从精准定位、分层设计、异步组件、拖拽四个方面分析飞码画布设计。 ## 一、精准定位设计 飞码画布是一个套件,可对外提供画布能力。精准定位有两种情况,一是目标组件无子组件,而是目标组件有子组件。 **无子组件**:目标组件分为支持与不支持放子组件两种情况。 **有子组件**:鼠标相对于子组件(目标组件)对角线位置。详见图1 <div style="display: flex; justify-content:center; width:100%"> <img src="https://storage.360buyimg.com/fei-ma/神灯使用/202207/07/01.png?time=1" width="75%"/> </div> <div style="display: flex; justify-content:center;width:100%"> <span>图1</span> </div> 当目标组件不支持放子组件时,需要计算拖拽组件放在目标组件的左侧、上侧、右侧、还是下侧?其计算方法如图2 <div style="display: flex; justify-content:center; width:100%"> <img src="https://storage.360buyimg.com/fei-ma/神灯使用/202207/07/02.png" width="55%"/> </div> <div style="display: flex; justify-content:center;width:100%"> <span>图2</span> </div> 通过鼠标位置,目标组件,组件对角线坐标位置可推导出图1右侧图拖拽组件与目标组件位置关系。 **问题**:飞码为何不提供尺度(x、y),这样可以精准知道组件大小? 实际使用过程中,搭建人员并不关心组件的具体x,y。一般关注一行几列与组件宽度。 ## 二、分层设计 低代码画布设计有很多方案,飞码采用的是双层设计模式。该设计模式优势很多,与画布中组件是解耦关系。开发过iOS,安卓native的同学较容易理解。如图3 <div style="display: flex; justify-content:center; width:100%"> <img src="https://storage.360buyimg.com/fei-ma/神灯使用/202207/07/03.png" width="75%"/> </div> <div style="display: flex; justify-content:center;width:100%"> <span>图3</span> </div> 画布中底层是组件渲染层,根据页面DSL渲染组件布局,在组件渲染层上还有一层canvas-mask视图。当点击某一个组件之后,根据组件会在组件最边框添加颜色,组件右侧上方(根据页面布局自动切换到下方)添加工具条(更多、上移、下移、复制、删除),hover区域。支持组件宽度拖拽调整,组件的最右侧有一个呼吸道效果的线条,鼠标可以对该组件宽度进行拖拽调整。这样极大方便了样式调整操作。 **问题**:既然支持了组件左右大小调整,为何不支持组件的上下大小调整? 飞码对div,form等容器组件在编辑态中上下大小会根据子组件高度进行自动调整。飞码并不知道组件的宽度大小。 ## 三、异步组件 飞码提供常用的组件能力,飞码搭建业务定制化的组件困难。飞码提供动态加载组件能力,动态组件加载分为编辑态与运行态。编辑态在组件拖到页面的时候会根据组件数据中type判断当前组件类型。若type=2,飞码引擎会创建script下载相关url对应的组件,之后做缓存。运行态思路一致。 ## 四、拖拽设计 拖拽组件的时,每一个组件需要混入一些特定处理,例如form表单的子组件是不是el-form-item等情况。见图4 <div style="display: flex; justify-content:center; width:100%"> <img src="https://storage.360buyimg.com/fei-ma/神灯使用/202207/07/04.png" width="65%"/> </div> <div style="display: flex; justify-content:center;width:100%"> <span>图4</span> </div> 组件拖拽开始会记录currentTarget获取到组件id,并对dataTransfer进行设置image。这样就可以看到拖拽组件的样式。混入方法使用hoc,增强组件的一个方法。详见图5所示。 <div style="display: flex; justify-content:center; width:100%"> <img src="https://storage.360buyimg.com/fei-ma/神灯使用/202207/07/05.png" width="55%"/> </div> <div style="display: flex; justify-content:center;width:100%"> <span>图5</span> </div> ## 四:小结 本章节分析了飞码画布在精准定位、分层设计、异步组件、拖拽四个方面的设计。飞码的目标是:便捷、稳健、0测试,使前端web单页面快速投产。感谢产品李红菲同学、服务端刘菲同学的大力支持。[飞码]
上一篇:飞码LowCode前端技术(五)
下一篇:飞码LowCode前端技术(六)
灰豆****
文章数
7
阅读量
4566
作者其他文章
01
飞码LowCode前端技术(一)
(背景与数据结构设计)作者:王光辉部门:京东科技-市场与平台运营中心-平台研发部-营销平台研发部简介飞码是京东科技-市场与平台运营中心-平台研发部研发低代码产品,可使营销运营域下web页面快速搭建。飞码是单web页面搭建工具,从创建页面到监测再到投产的一站式解决方案。会通过七篇文章介绍飞码,分别是:(1)背景与数据结构设计,(2)如何便捷配置出页面-1,(3)如何便捷配置出页面-2,(4)如何便捷
01
飞码LowCode前端技术(二)
(如何便捷配置出页面-1)作者:王光辉部门:京东科技-市场与平台运营中心-营销与数据资产部-营销及数据平台研发部简介飞码是京东科技-市场与平台运营中心-平台研发部研发低代码产品,可使营销运营域下web页面快速搭建。飞码是单web页面搭建工具,从创建页面到监测再到投产的一站式解决方案。会通过七篇文章介绍飞码,分别是:(1)、背景与数据结构设计,(2)、如何便捷配置出页面-1,(3)、如何便捷配置出页
01
飞码LowCode前端技术(四)
(如何便捷配置出页面-3)作者:王光辉部门:京东科技-市场与平台运营中心-营销与数据资产部-营销及数据平台研发部简介飞码是京东科技-市场与平台运营中心-平台研发部研发低代码产品,可使营销运营域下web页面快速搭建。飞码是单web页面搭建工具,从创建页面到监测再到投产的一站式解决方案。会通过七篇文章介绍飞码,分别是:(1)、背景与数据结构设计,(2)、如何便捷配置出页面-1,(3)、如何便捷配置出页
01
飞码LowCode前端技术(三)
(如何便捷配置出页面-2)作者:王光辉部门:京东科技-市场与平台运营中心-营销与数据资产部-营销及数据平台研发部简介飞码是京东科技-市场与平台运营中心-平台研发部研发低代码产品,可使营销运营域下web页面快速搭建。飞码是单web页面搭建工具,从创建页面到监测再到投产的一站式解决方案。会通过七篇文章介绍飞码,分别是:(1)、背景与数据结构设计,(2)、如何便捷配置出页面-1,(3)、如何便捷配置出页
灰豆****
文章数
7
阅读量
4566
作者其他文章
01
飞码LowCode前端技术(一)
01
飞码LowCode前端技术(二)
01
飞码LowCode前端技术(四)
01
飞码LowCode前端技术(三)
添加企业微信
获取1V1专业服务
扫码关注
京东云开发者公众号