189 8069 5689

JavaScript如何限定范围拖拽及自定义滚动条应用

小编给大家分享一下JavaScript如何限定范围拖拽及自定义滚动条应用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

创新互联成立10年来,这条路我们正越走越好,积累了技术与客户资源,形成了良好的口碑。为客户提供网站设计、成都网站制作、网站策划、网页设计、域名与空间、网络营销、VI设计、网站改版、漏洞修补等服务。网站是否美观、功能强大、用户体验好、性价比高、打开快等等,这些对于网站建设都非常重要,创新互联通过对建站技术性的掌握、对创意设计的研究为客户提供一站式互联网解决方案,携手广大客户,共同发展进步。

两个对象:div1 和 div2,其中div1是div2的父元素,div2只能在div1的范围内拖拽

JavaScript如何限定范围拖拽及自定义滚动条应用

图中,红点是鼠标的位置,两个绿色箭头相减的结果就是disX,最后oEvent.clientX - disX 就是绿色箭头的部分,这个长度就是判断是否“出格”的依据,也就是这个短的绿色箭头范围应该在0 ~ div2.offsetWidth - div1.offsetWidth之间!




 
 客户区可见范围限制拖拽
 
  * {
   padding: 0;
   margin: 0;
  }
  #div1 {
   width: 500px;
   height: 500px;
   background: orange;
   position: relative;
   left: 100px;
   top: 30px;
  }
  #div2 {
   width: 100px;
   height: 100px;
   background: black;
   position: absolute;
   border: 1px solid blue;
  }
 


 
  
 
    var oDiv1 = document.getElementById('div1');   var oDiv2 = document.getElementById('div2');   function getStyle(obj, attr) {    if (obj.currentStyle) {     return obj.currentStyle[attr];    } else {     return getComputedStyle(obj, null)[attr];    }   }   oDiv2.onmousedown = function(ev) {    var oEvent = ev || event;    // var disX = oEvent.clientX - oDiv2.offsetLeft;    // var disY = oEvent.clientY - oDiv2.offsetTop;    var disX = oEvent.clientX - parseInt(getStyle(oDiv2, 'left'));    var disY = oEvent.clientY - parseInt(getStyle(oDiv2, 'top'));    document.onmousemove = function(ev) {     var oEvent = ev || event;     var l = oEvent.clientX - disX;     var t = oEvent.clientY - disY;     if (l < 0) {      l = 0;     } else if (l > oDiv1.offsetWidth - /*parseInt(getStyle(oDiv2,'width'))*/oDiv2.offsetWidth) {      l = oDiv1.offsetWidth - oDiv2.offsetWidth;     }     if (t < 0) {      t = 0;     } else if (t > oDiv1.offsetHeight - oDiv2.offsetHeight) {      t = oDiv1.offsetHeight - oDiv2.offsetHeight;     }     oDiv2.style.left = l + 'px';     oDiv2.style.top = t + 'px';    };    document.onmouseup = function() {     document.onmousemove = null;//如果不取消,鼠标弹起div依旧会随着鼠标移动     document.onmouseup = null;    };   };  

基于上述原理,我们来做一个自定义滚动条,通过拖拽滚动条的位置来控制另一个对象的大小,比如一幅图。

JavaScript如何限定范围拖拽及自定义滚动条应用

JavaScript如何限定范围拖拽及自定义滚动条应用




 
 自定义滚动条
 
 #div1 {
  width: 600px;
  height: 20px;
  background: orange;
  position: relative;
  margin: 50px auto;
 }
 #div2 {
  width: 20px;
  height: 20px;
  background: green;
  position: absolute;
 }
 #div3 {
  width: 0;
  height: 0;
  margin: 20px auto;
 }
 #div3 img {
  width: 100%;
  height: 100%;
 }
 


 
 
           var oDiv1 = document.getElementById('div1');  var oDiv2 = document.getElementById('div2');  var oDiv3 = document.getElementById('div3');  oDiv2.onmousedown = function(ev) {   var oEvent = ev || event;   var disX = oEvent.clientX - oDiv2.offsetLeft;   document.onmousemove = function(ev) {   var oEvent = ev || event;   var l = oEvent.clientX - disX;   if (l < 0) {    l = 0;   } else if (l > oDiv1.offsetWidth - oDiv2.offsetWidth) {    l = oDiv1.offsetWidth - oDiv2.offsetWidth;   }   oDiv2.style.left = l + 'px';//l范围:[0,580]   //document.title = l / 580; //范围:[0,1]   var ratio = oDiv1.offsetWidth - oDiv2.offsetWidth;   var scale = l / ratio;   var w = 600 * scale;   var h = 370 * scale;   console.log(w);   oDiv3.style.cssText = ';width:' + w + 'px;height:' + h +'px;';   };   document.onmouseup = function() {   document.onmousemove = null;   document.onmouseup = null;   };  };  

以上是“JavaScript如何限定范围拖拽及自定义滚动条应用”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


标题名称:JavaScript如何限定范围拖拽及自定义滚动条应用
标题路径:http://cdxtjz.cn/article/gsihid.html

联系我们

您好HELLO!
感谢您来到成都网站建设公司,若您有合作意向,请您为我们留言或使用以下方式联系我们, 我们将尽快给你回复,并为您提供真诚的设计服务,谢谢。
  • 电话:028- 86922220 18980695689
  • 商务合作邮箱:631063699@qq.com
  • 合作QQ: 532337155
  • 成都网站设计地址:成都市青羊区锣锅巷31号五金站写字楼6楼

小谭建站工作室

成都小谭网站建设公司拥有多年以上互联网从业经验的团队,始终保持务实的风格,以"帮助客户成功"为已任,专注于提供对客户有价值的服务。 我们已为众企业及上市公司提供专业的网站建设服务。我们不只是一家网站建设的网络公司;我们对营销、技术、管理都有自己独特见解,小谭建站采取“创意+综合+营销”一体化的方式为您提供更专业的服务!

小谭观点

相对传统的成都网站建设公司而言,小谭是互联网中的网站品牌策划,我们精于企业品牌与互联网相结合的整体战略服务。
我们始终认为,网站必须注入企业基因,真正使网站成为企业vi的一部分,让整个网站品牌策划体系变的深入而持久。