前端拖拽组件优化

为什么弃用Html5 drag Api

  • 之前我也用的Drag Api写了一个draggable组件,使用起来总觉得体验有点不好。
  • 先来看有赞做的类似的拖拽UI组件,它引用的sortablejs库封装了Drag Api

图片描述

  • 1、拖拽的时候跟随鼠标的影子成为ghost,是Api自动生成的。但是由于这是一个很简洁的页面,背景全为白色在拖拽的时候其实很难看出拖到了哪里。Api虽然提供了e.dataTransfer.setDragImage(img, 0, 0)方法让我们在去改变这个ghost,但是设置的这个img必须是HTML img element、HTML canvas element,否则它必须是一个可见的节点。简单来说就是如果你设置的ghost不是canvas或者img元素,而是你自定义的html元素,那你必须把它append到document中。
    document.getElementById("drag-with-create-add").addEventListener("dragstart", function(e) {
        var crt = this.cloneNode(true);
        crt.style.backgroundColor = "red";
        document.body.appendChild(crt);
        e.dataTransfer.setDragImage(crt, 0, 0);
    }, false);
  • 这种方式好像解决了拖拽不明显的问题,但是设置的ghost是默认有一个透明度的,而且你没有办法去改变这个透明度。在上面显示的这个页面里面,即使是cloneNode一个元素出来跟随鼠标也由于这个原因有种不清晰的感觉。
  • 2、快速拖拽的时候元素在不停的回流和重绘

图片描述

  • 从上图可以看到在拖拽排序的时候dom顺序不断在变化,虽然说在拖拽的时候页面已经加载完,这点开销不会有太大的影响,但是如果能够做到一次拖拽只改变一次dom结构的话当然是最好的。
  • 3、示例的拖拽没有动画效果,而且ghost跟随给人的感觉有种很用力才能拖动,有点费劲。这个问题并不是吹毛求疵,在稍后优化后的draggable组件动画能够体现出来。

利用鼠标事件拖拽更流畅

图片描述

  • 优化之后的拖拽显然比示例的顺畅很多,不会有种吃力拖动的感觉。

图片描述

  • 拖动的过程中,无论怎么拖动,变化的只是元素的translate,并没有引起dom结构的变化,而translate并不会引起回流和重绘,而是在一次拖拽结束才进行一次更新排序。拖动过程中也能很明显地看出当前拖拽的元素。
  • 关于css影响文档流回流和重绘可以参考https://docs.google.com/sprea...

优化思路

  • 弃用html5的drag,改用mouse事件
  • mousedown的时候clone当前点击的元素为ghost并将原来的元素visibility:hidden;visibility让原来的元素依然占据着位置,是拖拽中不改变dom的关键。
  • 设置ghost的position为fixed,脱离文档流,这样无论怎么拖拽都不会影响到布局。
  • 将mousemove和mouseend事件添加到window上,这样无论鼠标怎么移动ghost都流畅跟随。mousemove的时候判断ghost与其他元素的位置,只使用translate去改变,直到真正拖拽结束才进行一次排序。
  • 优化后的自定义ghost能让人清晰得看到正在移动的元素。

配合vue使用的源码:https://github.com/sally2015/...,通过v-model轻松双向绑定数据列表

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
前端拖拽组件生成页面是一种通过拖拽组件来生成动态页面的方法。这种方法可以帮助开发者快速搭建页面,提高开发效率。在实际应用中,可以使用一些第三方插件来实现这个功能,比如vuedraggable。 vuedraggable是一个Vue.js的插件,它提供了一种简单的方式来实现拖拽组件。你可以通过拖拽组件来生成页面。具体的实现步骤如下: 1. 首先,在你的项目中引入vuedraggable插件。你可以通过在项目中引入draggable组件来使用该插件。 2. 然后,根据你的需求,结合相关的文档和示例代码,来进行开发。你可以根据自己的需求来定义拖拽组件的样式、属性和行为。 3. 接下来,你可以将需要拖拽组件放置在页面上,并配置好拖拽的规则和交互效果。你可以使用vuedraggable提供的一些API来实现拖拽组件的排序、限制拖拽的范围和处理拖拽事件。 4. 最后,你可以在浏览器中预览生成的动态页面,通过拖拽组件来实现页面的交互和布局调整。你可以根据需要对拖拽组件进行修改和优化,以满足项目的需求。 通过使用前端拖拽组件生成页面的方法,你可以更加灵活和高效地进行页面开发,同提供了一种可视化的方式来搭建页面结构。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [vue使用vuedraggable拖拽组件,进行组件生成](https://blog.csdn.net/m0_59023970/article/details/129798365)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [Vue拖拽组件列表实现动态页面配置功能](https://download.csdn.net/download/weixin_38732463/12940620)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值