位置: 编程技术 - 正文

javascript实现PC网页里的拖拽效果(运用javascript制作网页)

编辑:rootadmin

推荐整理分享javascript实现PC网页里的拖拽效果(运用javascript制作网页),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:网页javascript void,用javascript写简单网页,javascript网页编程,运用javascript制作网页,运用javascript制作网页,javascript网页编程,用javascript写网页,在网页上运行javascript,内容如对您有帮助,希望把文章链接给更多的朋友!

几年前,我参与设计开发一个房产网的项目,我负责前端工作,由于项目经理要求比较高,参考了很多房产类网站比较优秀的功能,想把别人比较优秀的设计和想法集合到一起,那时的设计稿和功能实现,简直就是改了又改,今天做好的一个很好的效果,可能第二天就要推到重来,算了,不说这些了,还是说说我们今天要讲解的案例吧,不知道大家访问过搜房网没有(完全没有做广告之嫌,搜房网,可以给点广告费不),其中有一个功能产品经理特别喜欢,那,就是下面的这个:

这是现在的效果,可能改了一些,原来的效果是,里面的这张图是可以上下左右拖动的,然后房子上面的显示的楼栋号,也跟着图片一起移动,当时js能力还不行,未能实现项目经理的要求,不过后来项目经理又把这个效果推掉了,换了另外的一个效果

尽管项目经理不想要这个效果了,但是当时就在我心里留下了一个节,到今天都忘不了这个梗。

好了,这就是我今天想写这篇博客的初衷,希望能给想实现这类拖拽效果,但是不知道该怎么去实现的同学,提供一种思路,不给青春留遗憾,当然实现拖拽的方法有很多,这里就只介绍JavaScript中的一种方法,慢慢体会一下其中的原理!

好了,梗也说完了,开始正题,我们先要明白,拖拽到底是一个什么东西,你也知道,我也知道,但是我还是想来描述一下:

拖拽就是一个容器,你用鼠标可以在页面上拖着到处跑,废话,精确的描述应该是,鼠标移到容器上,然后鼠标按下去,注意要按着不放,然后拖动鼠标,容器能跟着鼠标跑,松开鼠标,容器就停在那里不动了,现实中的例子就是桌子上有一个盒子,我用手放在盒子上,然后移动盒子,手停盒子停,手拿开,盒子不动了,嘻嘻,都懂了哈!

别以为上面说了一堆的废话,我们可以从中得到很多的信息,总结如下就是:

拖拽 = 鼠标按下 + 鼠标移动 + 鼠标弹上

这样就完成了一个拖拽任务,好了,原来这就是拖拽的原理,想实现拖拽,自然实现上面的3个动作,便可以模拟拖拽效果,好,对应JavaScript中的语法就是需要实现这3个动作:

onmousedown , onmousemove , onmouseup

实现的代码就应该是:

为什么后面2个动作要写的里面,好好回味一下,好了,第一步的大概思路就有了,下一步就需要考虑怎么让物体跟着鼠标一起移动,思路大概是这样的:

首先物体是需要决定定位的,因为我们需要操作它的left和top值,才能让它移动,然后就是要考虑鼠标了,鼠标位移,本身就会有一个距离,如果我们知道鼠标移动了多远,然后把这个距离给物体,那物体是不是也和鼠标一样,移动了相同的距离,这不就实现拖拽了吗?哈哈,思路一点点有,感觉萌萌哒~ 现在的问题就是怎么获取鼠标的距离,如果需要深入了解,请复习一下盒子模型,这里我就不说了,很多大神也有相关的博客,我用一张图表示一下:

说明:蓝色框为屏幕宽高,黑色粗框为浏览器可视区宽高(浏览器缩小效果),黑色细框为鼠标要拖拽的对象,如图可知,获取鼠标的坐标,可以用event.clientX,event.clientY来获取,哦了;

计算的大致原理可以参照下图:

javascript实现PC网页里的拖拽效果(运用javascript制作网页)

说明:左边为初始位置,右边为目标位置,原点为鼠标位置,大黑框为浏览器可视宽度,小黑框为拖拽对象,看拖拽对象到目标位置的状态,获取鼠标的最终位置,再减去鼠标距离对象的差值,再赋值给对象的top,left值,也可以获取鼠标的位置差值,再用初始的top,left值加上差值,我们采用第一种,第二种也可以,自己去试一下:

这里说明一下:onmousemove和onmouseup之所以用document对象而不用obj对象,是因为如果用obj对象,鼠标在obj内部还好,如果在obj外面的话,拖拽会很怪异,你也可以改成obj体会一下,最后我们在鼠标弹起的时候将事件都清空;

上面的基本拖拽就算完成了,但是细心的同学一定会问,如果页面上有文字的话,拖拽物体会将文字选中,这效果岂不是怪怪的,没错,这是因为拖拽的时候触发了浏览器的默认选择事件,所以,在拖拽的时候,我们要清除这个默认事件,那怎么清除呢?

下面给一个兼容性写法:

将上面的代码放在onmousedown下,鼠标按下就清除浏览器默认事件,文字就不会被选中了,好了,一个简单的拖拽效果就完成了,当然你现在是看不到效果,之所以不给demo链接是为了让你自己试着写一写,这样印象更深刻,

好了,那问题又来了,到这里就这样完了吗?。。。。。。按本人的风格,当然没有,干货还在后面!

如果我想实现这样一个效果,就是这一个大的容器里面(可以是box,也可以是document),怎么样能让我们的拖拽对象不跑出去呢,换句话说,拖到边缘就拖不动了,耶,是不是很多人想要实现的效果,哈哈,我们看看实现的原理是什么:

现实生活中,一个物体在一个盒子里跑不出去,是因为有堵墙,那我们只要能模拟出这堵墙,就可以把物体框起来,那这堵墙要怎么做呢?我们可以换个思路,当拖拽对象拖到边缘的时候,比如说拖到右边,我们将它的left固定住,是不是就不能再往右了,因为left值不能再加了,那么拖到底部,同理我们将top值固定住,就不能再往下拖了,理解吗?

最终的结果就是如下:

说明:pWidth,pHeight 表示父级元素的宽高(这里是表示相对于父级的宽高限制),oWidth,oHeigt表示拖拽元素的宽高

最后,我将整个拖拽代码整理了一下:

说明:我这里处理的效果是,如果传一个参数,表示相对的对象是window对象,如果传2个参数,第一个是拖拽对象,第二个为相对父级

开篇就说了,搜房网的那个图片拖拽效果是我的一个心结,我写了一个类似的效果,供大家参考,因为自己没有买服务器,所以效果我就不展示了,直接把代码贴出来,供大家参考:

css:

html:

javascript:

效果完全是用的那个封装代码块,引用起来也挺方便,有人会问了,你这用的id获取DOM元素,一个页面只能用一次啊,如果页面多次使用呢,有道理,解决方案之一,那就命名不同的id呗,又不犯法,方案二,获取id的地方改成获取class,但是要注意的是,getElementsByClassName是获取的class集合,需要改写一下,这里我就不写了,有兴趣的同学自行改写一下,好了,到这里真的结束了!

javascript实现数组去重的多种方法 废话不多说,直接拿干货!先说说这个实例的要求:写一个方法实现数组的去重。(要求:执行方法,传递一个数组,返回去重后的新数组,原数组不

使用javascript插入样式 一、用javascript插入style样式有时候我们需要利用js来动态生成页面上style标签中的css代码,方法很直接,就是直接创建一个style元素,然后设置style元素里

php基于redis处理session的方法 一个基于redis的处理session的方法,如下。phpclassSession_custom{private$redis;//redis实例private$prefix='sess_';//session_id前缀//会话开始时,会执行该方法,连接redis服

标签: 运用javascript制作网页

本文链接地址:https://www.jiuchutong.com/biancheng/377500.html 转载请保留说明!

上一篇:GitHub上一些实用的JavaScript的文件压缩解压缩库推荐(github常用操作)

下一篇:javascript实现数组去重的多种方法(javascript数学函数)

  • 调整税率后增值税发票的开具
  • 个人所得税起征点2023税率表
  • 企业为个人承担的个人部分社保
  • 购进的库存商品转自用需要开发票吗
  • 30万的车税可以抵多少
  • 小企业会计准则会计科目表
  • 无偿赠送货物怎么做账
  • 在账务处理过程中,最关键的环节是
  • 公司注销后专利还能转让吗
  • 长期投资包括哪些会计科目
  • 购买固定资产进项税率
  • 电商行业平台开的发票怎么入账
  • 海关特许权使用费 公告
  • 核定征收的企业需要做账吗
  • 国家税务总局2017 11号
  • 旅游业要怎么进行差额征税处理
  • 广告公司认定一般多少钱
  • 个税多申报了实发没有这么多,如何处理
  • 公司给另外一家公司投资
  • 收到快递关税做什么科目
  • 法人转钱进公账可以吗
  • 关于幼儿园会没课程的会刊
  • linux和windows关系
  • window11如何打开任务管理器
  • 法人不缴纳社保员工可以缴纳吗怎么办
  • player.exe是什么意思
  • 有进项没销项怎么处理,可以结转成本吗
  • 显卡性能排行榜2023
  • 公司员工借款怎么做账
  • php文件用什么运行
  • 西班牙的藏红花好不好
  • 股票印花税和佣金的关系
  • php xml转字符串
  • win10iis安装配置
  • joomla中文手册
  • php实现快速排序算法
  • java中文乱码解决总结
  • 增值税专用发票有几联?
  • phpstorm创建php文件
  • 车间打杂工
  • 网上报税流程演示2019
  • 工会经费,残保金,会计分录
  • 小企业发出存货成本的计量方法有
  • 购入固定资产的会计处理
  • 管理人员工资结构图
  • 预提费用汇缴时间怎么算
  • 资产减值损失的借贷方向
  • 个体工商户核算方式选哪个比较好
  • 为什么开票需要提供开户许可证
  • 应收账款贷方如何核算
  • 年报审计调整
  • 职工薪酬怎么核算
  • 软件测试收费标准2019
  • 个人独资企业取得拆迁补偿款税收规定
  • 赠送货物金额为多少
  • 会计凭证是对外公布的资料吗
  • 在sql server
  • 对于微软用户来说,为了防止计算机意外故障
  • centos的命令行界面输入
  • win7网页无法访问
  • 电脑开机时出现红色三角形
  • xp系统的搜索
  • win10web服务器在哪打开
  • Win8.164位/32位KB3096053补丁下载 主要修复KB3069114安装问题
  • centos 安装chia
  • win7通知区域图标无法设置
  • win10系统语言包安装方法
  • linux系统如何禁用光驱
  • 电脑arp攻击怎么解决
  • 如何用法向量求点到线的距离
  • Bootstrap与KnockoutJs相结合实现分页效果实例详解
  • java list转set的方法
  • js正则匹配特殊符号
  • ListView中EditText焦点问题
  • python程序开发
  • 南京税务局几点上班几点下班
  • 期间费用如何分摊到成本中
  • 代理记账公司简介模板范文
  • 营业税属于地方税
  • 个人所得税必须企业代扣代缴吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设