首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

拖拽牛逼,轻松实现一个自由拖拽的组件

在揭秘页面设计器时,我们重点分享了顺序排列布局的组件拖动方式,那篇文章[2]的评论中,有小伙伴问到自由布局的实现,那么我们在这篇文章中来分享一下自由布局拖动的实现原理,实现一个设计器组件自由拖动的最简demo...如何使元素支持拖动 实现组件的自由拖动的核心就是 html5 中新添加的全局属性 draggable 属性,该属性规定了元素是否可进行拖动。...元素可以进行拖动了,我们就可以通过元素的拖动事件进行拖动开始-结束的一些逻辑控制了,拖动事件主要分为两个类别,一类是拖动元素可以触发的: dragstart:鼠标点中元素并且开始移动时触发 drag:拖拽过程中持续触发...dragend:拖拽结束松开鼠标时触发 另一类是,是当拖拽元素到某个目标元素时,目标元素会触发的: dragenter:拖拽元素到目标上时触发 dragover:拖动元素在目标元素中,持续触发 dragleave...后记 这篇文章中我们实现了页面设计器组件自由布局的最简demo,让大家理解自由拖动的实现原理。至于里面还有一些细节的处理,大家可以根据自己的需要自行实现~对该系列文章感兴趣的小伙伴来一波关注吧。

1.7K30

HTML5 拖拽上传图片实例

因为标题写的是实例,所以本次就不做讲解了,因为这个实例我也算是东拼西凑整出来的,参考了大概5、6款拖拽上传的插件和demo,然后把其中好的地方挑出来,最后就成了这么一个实例,一起来看下吧(地址不能保证长久有效...dropupload.html   界面样式我是参考了一个国外的相册网站,改动不大,只是把鸟语转换成中文,以及上传时的样式也进行了改动,之所以选这个的原因就是,我很容易做扩展,它支持3种方式添加图片,一种拖拽上传...它很巧妙的把三种上传模式整合到了一起,而且你可以用IE浏览器浏览下,如果不支持HTML5,是没有拖拽上传图片的提示的,如图:   拖拽上传最重要的就是js部分的代码,它实现了70%的功能,另外30%仅仅是把图片信息提交到后台...获取文件列表 var fileList = e.dataTransfer.files; var img = document.createElement('img'); //检测是否是拖拽文件到页面的操作...主要实现代码是从“功能实现”开始的,这块具体为何这样操作,原理是什么,我就不多说了,大家可以参考下这篇文章:《人人网首页拖拽上传详解(HTML5 Drag&Drop、FileReader API、formdata

2.7K30

分享一个自由拖拽组件的实现思路

点击上方关注 前端技术江湖,我们一起学习,天天进步 最近的项目中遇到一个需求,在页面上添加一个可以自由拖拽、缩放、编辑颜色的 svg 图片,项目中引用了两个现有的插件,对插件进行解读之后略有心得,与大家分享一下...自由拖拽缩放的节点 —— react-rnd 说到拖拽,我们的第一反应当然是监听鼠标事件来修改 dom 元素的位置,而缩放的话,则是在对元素边界进行操作时重新修正元素的 position 和 width...此时我们理论上已经实现了 dom 元素的拖拽和缩放,但是在添加了 svg 图片之后我们很快发现,由于外层的拖拽是由 document.addEventListener 来实现的,但是我们在 mouseDown...此时我们发现,我们添加的 svg 图片已经可以自由拖拽和缩放了。...尾声 以上就是我们在做给页面上添加一个可以自由拖拽、缩放、编辑颜色的 svg 图片时总结的一些东西,希望对各位有所帮助。

2.2K40

彻底搞懂拖拽——基于鼠标事件的拖拽以及基于HTML5 API的拖拽完整实现

一、基于鼠标事件的拖拽 原理——onmousedown、onmousemove、onmouseup onmousedown 该事件会在鼠标按键被按下时触发 支持该事件的HTML标签: , <...解决方案 只需要实时计算拖拽的元素边框距离上下左右屏幕之间的距离就行了,具体代码如下: code: <!...至此使用鼠标事件的拖拽大功告成!...---- 二、基于HTML5拖拽API的拖拽 前序知识介绍   一个典型的拖拽操作是这样的:用户用鼠标选中一个可拖动的(draggable)元素,移动鼠标到一个可放置的(droppable)元素,然后释放鼠标...当用户开始拖动一个元素或选中的文本时触发 drop ondrop 当元素或选中的文本在可释放目标上被释放时触发 ps:当从操作系统向浏览器中拖动文件时,不会触发dragstart 和dragend 事件 接口: HTML5

3.1K30

采用HTML5之data-机制自由提供数据

周末总是过得很快,又到了跟代码亲密接触的日子,我在北京向各位问好,今天我分享一点关于前端的东西,HTML5之标签"data-*"自定义属性的值传递。        ...今天我就给各位记录其中的一种,就是HTML5的"data-*"机制,它是一种标记语言标签的自定义属性,完全可以依靠这种机制自由地向后台提供各种数据,极其方便,当然,这种自定义属性的值可以通过jQuery...好了,下面正式来说说HTML5的"data-*"的机制提供数据,并如何获取。因为之前在更换页面的过程中也看到了公司使用"data-*"的机制来输送数据,但是对它的印象不是太深,就没有深究。...感觉这种方式输送数据对于我们Java开发者来说是非常有用的,因为有时候复杂业务的实现就在于数据传输的行不通而导致一种很好的实现思路就此熄灭,这个完全是我个人的感受,因为在以前开发中有多次这种欲达而不达的痛苦经历,如果能够自由灵活的通过各种方式无困难传递各种参数

652100

拖拽自由组合,让你的开发更加简单,用户更方便

今天给大家推荐一个自由拖拽自由组合的控件,这个控件是我自定义写的。通过它,我们可以自由拖拽自由组合实现一个界面,满足一个用户自由组合界面的需求。...这里不是通过自由拖拽控件,来快速开发一个界面,而且更人性化的让用户去自由组合一个界面。...1 前言 最近有一个项目,有一个主界面,界面上有很多控件或者有多个 fragment 组成,大小不一,而且由于用户需要,需要自由拖动和自由组合,形成用户自己需要的组合成的模样。...3 实现思路 3.1 首先 首先,我们来想想,要是实现各个子控件和视图之间的拖拽和交换位置,那这就意味着所有的子视图和控件必须在一个层级之内,否则跨层级的拖拽是非常难实现的。...其实方法也一样很简单,那就是: 记住每个子控件拖拽后的位置,并保存,在 onLayout 方法中,读取记录的位置 在这里,我给每个视图和控件都增加了一个 tag ,在拖拽的时候根据 tag 知道拖拽的是哪个控件和视图

1.1K60

【javascript】谈谈HTML5—Web Worker+canvas+indexedDB+拖拽事件

为什么学习HTML5? 咳咳, 回到主题,为什么我们要学HTML5呢?...1.了解HTML5的囊括范围的一大好处是:当你不小心使用了一个H5的东东的时候(例如你试图通过百度找到的答案解决一个紧张的需求),你会很及时的关注它的兼容性 2.H5有些新增的特性也许你从没接触过,也感觉无需用到它...如何使得被拖拽元素可拖拽?(因为元素默认的行为是不可拖拽的),以及如何使得被放置的容器元素可放置?...appendChild之类的API实现添加被拖拽的元素,从而模拟整个拖拽的过程 也就是说, 拖拽其实可分为三个过程: 拖动—传递被拖动元素的数据(如id)—在容器元素中添加该元素 关键在于如何在被拖动元素和被放置元素中传递数据...拖拽后 ? 参考资料: HTML5-MDN https://developer.mozilla.org/zh-CN/docs/Web/Guide/HTML/HTML5 【完】 ?

3.7K100

【javascript】谈谈HTML5: Web-Worker、canvas、indexedDB、拖拽事件

为什么学习HTML5? 咳咳, 回到主题,为什么我们要学HTML5呢?...1.了解HTML5的囊括范围的一大好处是:当你不小心使用了一个H5的东东的时候(例如你试图通过百度找到的答案解决一个紧张的需求),你会很及时的关注它的兼容性 2.H5有些新增的特性也许你从没接触过,也感觉无需用到它...如何使得被拖拽元素可拖拽?(因为元素默认的行为是不可拖拽的),以及如何使得被放置的容器元素可放置?...appendChild之类的API实现添加被拖拽的元素,从而模拟整个拖拽的过程 也就是说, 拖拽其实可分为三个过程: 拖动—传递被拖动元素的数据(如id)—在容器元素中添加该元素 关键在于如何在被拖动元素和被放置元素中传递数据...拖拽后 ? 参考资料: HTML5-MDN https://developer.mozilla.org/zh-CN/docs/Web/Guide/HTML/HTML5 【完】

3K30

html5简单拖拽实现自动左右贴边+幸运大转盘

此篇文章主要实现两个功能: 1、点击屏幕下方签到悬浮按钮; 2、弹出幸运大转盘,转盘抽奖签到 效果如图: ​ 在网上找了很多移动端拖拽的js实现方式,大部分都是这一种,html5的touch事件,但是没找到点击按钮可以向两边贴边的拖拽...代码如下: 1 $(function(){ 2 3 //签到按钮拖拽 4 //首先,设置cookie值,使到不同的页面刷新拖拽的按钮位置不会变 5 function setCookie(name...'; 48 //由于页面中会有滚动,所以在这不能用pageX和pageY,要用clientX clientY 49 50 } 51 }, false); 52 53 //拖拽结束...,放手 54 dragBox.addEventListener('touchend',function(event) { 55 // 如果这个元素的位置内只有一个手指的话 56 //拖拽结束...参考链接:原生js完美拖拽,每次刷新可以记住上次拖拽的位置

4.2K50

一步HTML5教程学会体系

HTML5是HTML最新的版本,万维网联盟。 HTML5是下一代的HTML标准,HTML5是为了在移动设备上支持多媒体。...article,footer,header,nav,section calendar,date,time,email,url,search HTML5语法 HTML5标签名大写,属性的双引号可选,属性值可选...ondragstart script 拖拽操作开始时触发 ondrop script 拖动的元素被放置时触发 ondurationchange script 媒体时长改变时触发...password 用于敏感信息的自由形式的文本字段,名义上没有换行符。 checkbox 预定义列表中的一组零个或多个值。 radio 一个枚举值。 submit 一个自由形式的启动表单的按钮。...textarea 自由形式的文本字段,名义上没有换行的限制。 button 自由形式的按钮,可以启动按钮相关的任何事件。

1.2K20

自由体验

自由的感受 玩家在游戏中寻找自由的感觉,但是,完全的自由事实上意味着无限的可能性,同时也意味着极大的不确定性。大多数人其实并不喜欢那样的自由,他们会感到不知所措。...我们需要给玩家「自由的感觉」,并不是说要给他们「真正的自由」,在游戏世界里真正存在的只是感受。一个聪明的设计师懂得如何在自由有限,甚至没有自由的情况下创造出自由的体验。...,客户虽然会对如此强大的自由度印象深刻,但接下来他们会更不知所措。...总结 ---- lens #71 自由自由感是区别游戏和其他娱乐方式的一个重要方面,保证玩家尽可能多地感到自由,询问自己如下问题: 什么时候玩家可以自由行动?这时候他们感到自由了吗?...有什么地方我可以让玩家感受到更多的自由? 有什么地方因为我给予玩家过多的自由反而让他们感到不知所措了?

69160
领券