24行代码,让你的网页元素任意放大、缩小、拖拽、移动

jQuery
433
0
0
2022-08-07

花了点时间写的,蛮长时间了。个人很喜欢,一段很简单的代码,却能够实现很多功能。(因为代码文字呈现没有格式,难以阅读,以后小编提供的代码都以截图方式呈现,底部有源码链接)。

到底多简单,先来看代码

基于jQuery

24行代码,让你的网页元素任意放大、缩小、拖拽、移动

基于jQuery

拖拽实例图:

24行代码,让你的网页元素任意放大、缩小、拖拽、移动

拖拽实例图

将代码剥离,只要写5行就可以实现拖拽了,是不是很简单:

24行代码,让你的网页元素任意放大、缩小、拖拽、移动

调用方式

放大、缩小

我们给拖拽增加点功能,支持放大、缩小,先看实例图:

24行代码,让你的网页元素任意放大、缩小、拖拽、移动

放大、缩小

将代码剥离,原先的代码保留不变,增加一个绑定事件:

24行代码,让你的网页元素任意放大、缩小、拖拽、移动

放大、缩小

这样来实现放大、缩小、拖拽是不是很简单,还能实现很多其他效果,大家慢慢领悟。

原理分析:

放大、缩小、拖拽都离不开在网页上拖动鼠标,对于前端来说就是 document 的 mousemove,当鼠标在网页上移动的时候,无时无刻不在触发 mousemove 事件,当鼠标触发事件时,什么时候需要执行我们特定的操作,这就是我们要做的了。我在 mousemove 中增加了几个对象来判定是否进行操作:

  • move:是否执行触发操作
  • move_target:操作的元素对象
  • move_target.posix:操作对象的坐标
  • call_down:mousemove的时候的回调函数,传回来的this指向document
  • call_up:当鼠标弹起的时候执行的回调函数,传回来的this指向document

小提示:

  • 简单的操作,只需要设定 move_target 对象,设置 move_target 的时候不要忘记了 move_target.posix 哦;
  • 复杂的操作可以通过call_down、call_up进行回调操作,这个时候是可以不用设置 move_target 对象的

深入研究

拖拽和放大、缩小实现了,但是有个问题,当我们鼠标点击并滑动的时候,是会选中文本的,为了避免这个问题,大家可以自行百度

css 阻止文本选中

24行代码,让你的网页元素任意放大、缩小、拖拽、移动

css 阻止文本选中

网页的放大、缩小、拖拽事件就研究到这里了,小编不再对如何拓展进行深入讲解,一切靠大家自行研究,权当课后作业了。~~

源码链接地址:

http://orzcss.com/posts/d554a392/

本文内容均属个人原创作品,转载此文章须附上出处及原文链接。

加关注,定时推送,互动精彩多,若你有更好的见解,欢迎留言探讨!