移动端实现元素拖拽效果插件_基于自然流布局的可视化拖拽搭建平台设计方案...

f307f2b3bbf60949a2e065019a0d3b95.png

LowCode 是高效、高性能的拖拽式低代码开发平台. 也是笔者最近一直在研究的方向, 对于可视化搭建平台的实现方案笔者之前写过很多文章, 这里带大家探索一个新方向——基于自然流布局的可视化搭建平台.

在我们之前实现的 h5-dooring 搭建平台中, 我们采用了网格布局的方式来实现拖拽生成H5页面或者Web app, 其好处就是灵活简单, 用户基本没有任何使用成本, 在前端层也能做一定的横向扩展, 但是存在几个缺陷:

  • 实现嵌套组件比较复杂
  • 没有层的概念

虽然通过改造可以实现层和嵌套的问题, 最近也在努力往这个方向实现(虽然和设计初衷相驳, dooring的初衷是抹去层和嵌套的概念, 让搭建扁平化和智能化, 所以没有采用自由布局的方案)

904ef56ac705ad41ed929cade4c5d0a3.png

但是如果一定要实现嵌套和层的功能, 有没有另一种更简单的方案呢? 笔者目前想到了两种解决方案:

  • 将智能布局改为自由布局, 即可以采用类似 react-resizable 的这种方案

  • 基于自然流来实现, 也就是抹去定位的概念, 完全基于元素在文档的顺序, 层级和定位的选择权交给用户

因为第一种方案笔者在dooring的早期已经实现过一版, 最后弃用采用了网格布局, 所以说我们来探讨一下第二种方案的实现.

基于自然流布局实现拖拽生成页面

自然流布局的好处就是我们不用通过定位的方式来限定元素的位置等信息, 而是以html文档流的方式来布局元素, 并且用户可以灵活的设置元素的层级(layer)和偏移(transform), 接下来我们来看看简单的实现效果.

1. demo效果

bb1cead4df974cafa691d7f6c78ab050.pngacef791bc112b78812a0e6098fd5cd3a.png

由上图的demo我们可以发现组件在画布中的布局完全是默认的文档流的方式, 所以我们有更灵活的布局实现.

2. 实现思路

具体实现思路主要分以下几个部分:
  • 组件区拖拽至画布
  • 画布区拖拽
  • 组件编辑器和更新机制
第一点和第三点我们在 H5-dooring中已经实现了, 感兴趣的可以看我之前的文章, 我们这里重点来实现画布区拖拽, 也是比较核心的环节.

2.1 H5拖放api基本介绍

拖放(Drag 和 drop)是 HTML5 标准的组成部分, 早已被大多数浏览器支持. 我们目前使用的拖放插件基本上基于 H5 拖放 API 来实现的, 其实实现第一点组件区拖拽至画布我们完全可以用原生来实现, 这里笔者简单来介绍以下.

首先我们来看看一个完整的拖放过程:

  1. 首先要设置一个元素可拖放(比如)

  2. 设计拖动的时候会发生什么(需要用到ondragstart事件 和 setData(你要传递的数据))

  3. 放到何处,也就是目标容器(通常在目标容器上绑定ondragoverondrop事件)

有了以上3个步骤, 我们就能实现第一点的需求, 笔者写个简单demo来给大家参考一下:

<script type="text/javascript">function allowDrop(ev) {
    ev.preventDefault();
  }function drag(ev){
    ev.dataTransfer.setData("Text",ev.target.id);
  }function drop(ev){
    ev.preventDefault();let data=ev.dataTransfer.getData("Text");
    ev.target.appendChild(document.getElementById(data));
  }script>

<div id="box" ondrop="drop(event)" ondragover="allowDrop(event)">div>
<img id="drag" src="dooring.png" draggable="true" ondragstart="drag(event)" width="336" height="69" />

也就是对应的我们的组件拖放区域, 如下图所示:

20f2c22e89ee2892444e03c74ae5d534.png

2.2 画布区拖拽布局实现

因为之前的版本我们采用了网格布局来实现智能拖拽, 由于内部定位机制采用的是绝对定位(absolute), 所以是实现层级和固定组件比较困难, 如果组件的呈现完全脱离了定位的束缚, 我们就可以实现以上的困境了. 所以这里我们调研了一种方案——拖拽排序机制.

自然流布局的规律就是默认情况下html页面是基于dom出现的顺序来排列的, 也就是我们说的堆叠.

0f3bec65e5e1229ebd0fe2741164b446.png

我们可以遵循这样的设计, 通过排序的方式改变组件的位置从而实现自然流布局的页面搭建.

那么我们再回到上面说的布局问题, 比如说要想实现栅格化布局, 我们只需要定义一个flex容器, 将组件拖拽到容器里就好了, 这样也就解决了嵌套的问题. 同时我们还可以设计嵌套容器的栅格数, 这样就可以实现类似如下的效果:

ad464081d5acecb0436721a3148ce3ac.png
拖拽排序的库我们可以使用:
  • sortable
  • Vue.Draggable
  • react-dnd
还有很多优秀的库, 这里就不一一举例了.

3. 如何实现层级和嵌套

其实在上面的实现思路中我们已经解决了嵌套的问题了, 即提供拖放的容器组件, 利用笔者在上文中介绍的拖放api即可实现. 对于组件层级来说, 因为我们采用的是自然流布局, 所以我们可以轻松的设置元素的定位属性, 比如我们提供一个定位的设置:

50c14b858473f7ee852db459376acc0e.png

关于如何设计一个动态的属性编辑器, 笔者之前文章中也就详细的介绍, 大家可以参考:
  • 表单编辑器实现(FormEditor)
以上就是自然流布局的基本实现方式, 后续笔者也会在github上同步我们最新的成果.H5-Dooring编辑器wiki: https://github.com/MrXujiang/h5-Dooring/wiki

最后

觉得有用 ?喜欢就收藏,顺便点个吧,你的支持是我最大的鼓励!微信搜 “趣谈前端”,发现更多有趣的H5游戏, webpack,node,gulp,css3,javascript,nodeJS,canvas数据可视化等前端知识和实战.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/365704.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python数据分析前提-----pandas

pandas&#xff1a;知识脑图 https://bigquant.com/community/t/topic/129755 1、read_csv(url)&#xff1a;读取数据 2、help(read_csv)&#xff1a;打印函数相关用法 3、数据名.dtypes&#xff1a;读取数据的类型&#xff08;int、float……&#xff09; 4、type(数据名&…

07-数据类型

【转】07-数据类型 介绍 存储引擎决定了表的类型&#xff0c;而表内存放的数据也要有不同的类型&#xff0c;每种数据类型都有自己的宽度&#xff0c;但宽度是可选的 详细参考链接&#xff1a;http://www.runoob.com/mysql/mysql-data-types.html mysql常用数据类型概括&#x…

小谈React、React Native、React Web

React有三个东西&#xff0c;React JS 前端Web框架&#xff0c;React Native 移动终端Hybrid框架&#xff0c;React Web是一个源码转换工具&#xff08;React Native 转 Web&#xff0c;并之所以特别提出&#xff0c;是觉得还有些用处&#xff09;。 React、React Native共同…

yii::$app-mongodb 查询纪录数_老詹总决赛有多强?12项数据领先乔丹科比,已握10项数据纪录...

勒布朗詹姆贡献了38分16个篮板和10个助攻的狂暴三双数据&#xff0c;并率领湖人淘汰了掘金&#xff0c;这使得他迈进了职业生涯第10次总决赛舞台。我们都知道&#xff0c;詹姆斯几乎统治着NBA季后赛大部分数据纪录&#xff0c;事实上&#xff0c;他在总决赛同样如此。根据《sta…

摆脱困境:从计划作业中调用安全方法

假设我们已经实现了一个Spring支持的应用程序&#xff0c;并使用Spring Security的方法安全性表达式对其进行了保护 。 我们的下一个任务是使用安全方法实施计划作业。 更具体地说&#xff0c;我们必须实现一个计划的作业&#xff0c;该作业从我们的服务类中获取一条消息&…

前端共享桌面_2020 前端学习路线总结,哎呦,不错哦!

2020 前端学习路线总结在 GitHub 看到一个很不错的前端学习路线图&#xff08;roadmap&#xff09;&#xff0c;从前端基础到前端工程化&#xff0c;再到跨端&#xff0c;都有知识点的覆盖&#xff0c;非常推荐阅读。图下面是我翻译的一个文字版&#xff0c;可以先看图再看文字…

每日一题题目16:简单的python练习题(1-10)

#1.python程序中__name__的作用是什么?__name__这个系统变量用来表示程序的运行方式. 如果程序在当前膜快运行,__name__的名称就是__main__, 如果不在(被调用),则显示为导入模块的名称.扩展:常常这样写if __name__ "__main__":来表名这是整个工程开始运行的入口.效…

Confluence 6 高级性能诊断

请在你的系统服务请求中包括下面所有的信息&#xff0c;如果可能的话&#xff0c;你也可以在请求中包括你认为最有可能出现的问题。这样的话&#xff0c;可以避免我们进一步对你系统的问题进行询问。 系统信息 Confluence 服务器 你系统信息的屏幕截图 Confluences Administrat…

RequireJS使用注意地方

使用RequireJS做异步模块加载&#xff0c;有几点值得注意的地方&#xff1a; 1.模块定义两种写法 1. 存在依赖的函数式定义 如果模块存在依赖&#xff1a;则第一个参数是依赖的名称数组&#xff1b;第二个参数是函数&#xff0c;在模块的所有依赖加载完毕后&#xff0c;该函…

WildFly上具有AngularJS的Java EE 7和Java WebSocket API(JSR 356)

这篇博客文章描述了用于WebSocket协议的Java API&#xff08;JSR 356&#xff09; &#xff08;这是Java EE 7平台的四个最新JSR之一&#xff09;&#xff0c;并提供了部署在WildFly 8上并可以在OpenShift上在线获得的具体应用程序。 [FR]版本的法语&#xff08; HTML或PDF &a…

用python做自我介绍_python入门教程NO.2 用python做个自我介绍

本文涉及的python基础语法为&#xff1a;数据类型等数据类型1. 字符串的拼接我们在上一章中已经简单介绍了一下字符串的创建方式&#xff0c;这里我们简单学习一下字符串的运算和拼接。字符串的运算字符串的加法#把字符串&#xff1a;hello赋值给变量aa hello#把字符串&#x…

想清楚映射规则,栈、队列、双端队列的实现都差不多

今天开始&#xff0c;啃读算法导论第10章。既然是啃就要有啃的样子&#xff0c;我决定将例题和习题全部用C实现一遍&#xff0c;总结同一类问题的共性。 10.1节介绍了栈&#xff0c;队列&#xff0c;双端队列及一些组合形式&#xff0c;为了突出体现思路&#xff0c;让代码更加…

日期加减加1天_2小时整理了13个时间日期函数,动图演示简单易学,收藏备用吧...

Hello&#xff0c;大家好&#xff0c;今天跟大家整理汇总了13个工作中经常用到的日期与时间函数的使用方法&#xff0c;学会它们几乎可以解决所有工作中遇到的&#xff0c;关于日期与时间提取与转换的问题。话不多说&#xff0c;让我们直接开始吧一、了解时间与日期的本质工作中…

T-1-java语言基础

一、Linux的由来和发展Linux是开源的操作系统Linux是服务器端的操作系统java主要用于服务器端二、Linux目录结构&#xff08;与Windows不同&#xff09;文件系统不同&#xff1a;Windows是盘符&#xff0c;Linux是目录。外部设备映射不同&#xff1a;Windows是盘符&#xff0c;…

点云数据显示_vispy 显示 kitti 点云数据

国内博客找了一圈&#xff0c;居然没有发现有用 vispy 做可视化的代码&#xff0c;这里做一个简单的示例&#xff0c;代码大部分来自官方。import numpy as np import vispy.scene from vispy.scene import visuals import sys# Make a canvas and add simple view canvas vis…

python函数定义关键字_Python(2)深入Python函数定义

在Python中&#xff0c;可以定义包含若干参数的函数&#xff0c;这里有几种可用的形式&#xff0c;也可以混合使用&#xff1a;1. 默认参数最常用的一种形式是为一个或多个参数指定默认值。>>> def ask_ok(prompt,retries4,complaintYes or no Please!):while True:ok…

稳定婚姻(tarjan)

传送门 这道题一开始可能以为是二分图匹配……&#xff1f;不过后来发现和二分图没啥大关系。 简单分析之后发现&#xff0c;把夫妻之间连边&#xff08;男性向女性连边&#xff09;&#xff0c;之后再将每对曾经是情侣的人连边&#xff08;女性向男性连边&#xff09;&#xf…

Webpack 常用命令总结以及常用打包压缩方法

前言&#xff1a;Webpack是一款基于node的前端打包工具&#xff0c;它可以将很多静态文件打包起来&#xff0c;自动处理依赖关系后&#xff0c;生成一个.js文件&#xff0c;然后让html来引用&#xff0c;不仅可以做到按需加载&#xff0c;而且可以减少HTTP请求&#xff0c;节约…

在Spring MVC Web应用程序中添加社交登录:单元测试

Spring Social 1.0具有spring-social-test模块&#xff0c;该模块为测试Connect实现和API绑定提供支持。 该模块已从Spring Social 1.1.0中删除&#xff0c;并由 Spring MVC Test框架替换。 问题在于&#xff0c;实际上没有有关为使用Spring Social 1.1.0的应用程序编写单元测…

CSS3 Filter详解(改变模糊度 亮度 透明度等方法)

文章目录 1.模糊2.灰度3.亮度4.对比度5.饱和度6.色相旋转7.反色8.阴影9.透明度10.褐色CSS3 Filter&#xff08;滤镜&#xff09;属性提供了提供模糊和改变元素颜色的功能。CSS3 Fitler 常用于调整图像的渲染、背景或边框显示效果。 -webkit-filter是css3的一个属性&#xff0c;…