当前位置: 首页 > news >正文

全景效果图网站毕设做桌面端还是网站

全景效果图网站,毕设做桌面端还是网站,图片设计师网站,苏州做网站比较好的公司demo效果: 鼠标移入盒子,按下鼠标,开启移动跟随移动模式,再次按下关闭移动模式 涉及主要属性 在元素上单击鼠标按钮时输出鼠标指针的坐标: var x event.pageX; // 获取水平坐标 var y event.pageY; // 获取垂直坐标元素offsetL…

demo效果:

鼠标移入盒子,按下鼠标,开启移动跟随移动模式,再次按下关闭移动模式

涉及主要属性

在元素上单击鼠标按钮时输出鼠标指针的坐标:

var x = event.pageX;     // 获取水平坐标
var y = event.pageY;     // 获取垂直坐标

元素offsetLeft和offsetTop属性:
相当于最近一个有定位的父元素而言的位置,如果父元素没有定位则相当于body的x,y位置。

还有元素的offsetXXX属性不能修改只能用来读取(比如不能写:元素.offsetLeft=200),所以如果要使用(元素.style.xxx)来修改对应的原始位置
元素的offsetXXX和元素的style属性的区别:
1、offsetXX属性只读,style属性可以修改(最主要的区别)
2、offsetXX可以获取任何样式表上的样式,style属性则只能获取style=‘xxx’(行内样式)
3、还有其他的区别可以自己去搜搜嘻嘻

思路:

1、鼠标移入盒子,按下鼠标:开始计算在盒子的相对位置relativeX,relativeY
在这里插入图片描述

2、监听鼠标在盒子里面的移动(盒子和鼠标的位置关系始终保持不变)
3、根据鼠标位置和鼠标相对于盒子的位置计算得出当前盒子位置
在这里插入图片描述
4、鼠标再次点击取消跟随移动

具体代码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>/* 清楚浏览器样式 */*{margin: 0;border: 0;}.box{width: 300px;height: 300px;  background-color: brown;position: relative;left: 200px;top: 200px;}</style>
</head>
<body><div class="box" id="box"></div><script >let boxEl = document.getElementById('box')let relativeX =  0let relativeY = 0let needMoving = false// 盒子跟随鼠标移动boxEl.addEventListener('click',(event)=>{// 盒子内部点击 修改是否跟随鼠标移动needMoving = !needMoving//计算相对位置if(needMoving){boxEl.style.cursor = 'grab'boxMoveWithMouse(event,boxEl)document.addEventListener('mousemove', changeElXY)}else{relativeX =  0relativeY = 0boxEl.style.cursor = 'default'//  移除鼠标移动事件document.removeEventListener('mousemove', changeElXY);}})// 鼠标移入盒子 盒子跟随鼠标移动function boxMoveWithMouse(e,el){// 鼠标在文档位置let  pageX = e.pageXlet  pageY = e.pageY// 盒子在文档位置let boxOffX = el.offsetLeftlet boxOffY = el.offsetTop// console.log('boxOffX',boxOffX)// console.log('boxOffY',boxOffY)// 盒子在文档相对位置relativeX = pageX - boxOffXrelativeY = pageY - boxOffY// console.log('relativeX',relativeX)// console.log('relativeY',relativeY)}//修改元素位置function changeElXY(event){//  //鼠标不在盒子里面if(relativeX<0||relativeY<0){return}let pageX = event.pageXlet pageY = event.pageY//  console.log('pageX',pageX)//  console.log('pageY',pageY)// 盒子位置let boxX = pageX - relativeXlet boxY = pageY - relativeY// console.log('boxX',boxX)// console.log('boxY',boxY)//修改盒子位置boxEl.style.left = boxX+'px'boxEl.style.top = boxY + 'px'}</script>
</body>
</html>

效果演示

在这里插入图片描述

http://www.yayakq.cn/news/103339/

相关文章:

  • 永康网站开发个人网站首页界面
  • 网站开发人员 生活dw网页设计代码模板源代码
  • 做dm素材网站最好的包装设计公司哪家好
  • 做数据分析网站校园社交网站怎么做
  • 邹平网站建设公司衡水做企业网站的公司
  • 门户网站建设考核总结北京北控京奥建设有限公司网站
  • 校园网站建设特色wordpress和dada
  • 网站设计 图片商务网站建设与维护
  • 做网站上面图片的软件商丘软件开发
  • 网站作业二级网页建成局网站建设
  • 网站建设需要哪些方面安徽城乡建设厅官网站
  • 怎样在手机上建设网站做网站 会计分录
  • 商业网站策划书范文班级网页设计模板html
  • 网页设计师培训教程宁波seo关键词优化
  • seo诊断网站免费诊断平台高端建站神器
  • 网站备案号怎么申请建站优化办事效率高
  • 网站开发运营费用宿迁公司做网站
  • 淘宝客领券网站怎么做googl浏览器做桌面版网站
  • 简述建设一个网站的具体过程工信部网站备案查询
  • 网站跟app的区别福建省网站备案
  • wordpress 英语宁波谷歌seo推广
  • 长春找工作哪个网站好济南槐荫网站开发公司
  • 长春网站制作企业企业咨询公司收费标准
  • 网站建设ssc源码电子商务网店运营
  • 申报网站站内优化怎么做
  • 泰安网站建设收费标准品牌网站设计提案
  • 信息网站建设方案网址怎么申请
  • 淘宝上做微请帖的在哪个网站wordpress 正版插件
  • 网站百度收录很多意识形态网站建设
  • 网站内页设计专业素材网站