• JavaScript动画-磁性吸附


    ▓▓▓▓▓▓ 大致介绍

      磁性吸附是以模拟拖拽为基础添加一个拖拽时范围的限定而来的一个效果,如果对模拟拖拽有疑问的同学请移步模拟拖拽

      源代码、效果:点这里

    ▓▓▓▓▓▓ 范围限定(可视区)

      先来看一个在可视区范围内的模拟拖拽,我们先要搞清楚可视区的范围。

      可视区就是用户可以看到的区域,有上、下、左、右四个范围

      上:T = 0

      下:B = document.documentElement.clientHeight

      左:L = 0

      右:R = document.documentElement.clientWidth

      

      我们控制div在可视区范围内拖拽就是设置div的left和top值,从下图我们可以看到left和top应设置的值

      代码中用L和R记录方块的坐标值

      代码如下:

     1                 if(L < 0){
     2                     // 左侧范围
     3                     L = 0;
     4                 }else if(L > document.documentElement.clientWidth - obj.offsetWidth){
     5                     // 右侧范围
     6                     L = document.documentElement.clientWidth - obj.offsetWidth;
     7                 }
     8                 if(T < 0){
     9                     // 上侧范围
    10                     T = 0;
    11                 }else if(T > document.documentElement.clientHeight - obj.offsetHeight){
    12                     // 下侧范围
    13                     T = document.documentElement.clientHeight - obj.offsetHeight;
    14                 }

      

    ▓▓▓▓▓▓ 磁性吸附

      磁性吸附就是在范围限定的基础上改进得来的

      如图:

      我们把方块拖到距离可视区边界30px的位置,放快就自动的吸附到边框上。

      代码:

     1                 if(L < 50){
     2                     // 左侧范围
     3                     L = 0;
     4                 }else if(L > document.documentElement.clientWidth - obj.offsetWidth - 50){
     5                     // 右侧范围
     6                     L = document.documentElement.clientWidth - obj.offsetWidth;
     7                 }
     8                 if(T < 50){
     9                     // 上侧范围
    10                     T = 0;
    11                 }else if(T > document.documentElement.clientHeight - obj.offsetHeight - 50){
    12                     // 下侧范围
    13                     T = document.documentElement.clientHeight - obj.offsetHeight;
    14                 }

      

  • 相关阅读:
    Effective.Java第67-77条(异常相关)
    淘宝店的图片哪里来的
    SEO高手在扯蛋?
    多少人,没能熬过那最初的三厘米!
    网站要提高权重要总结三点
    真正的干货是什么?
    google打不开怎么办?谷歌打不开的解决方法
    StatCounter
    教你如何抢注一个快过期的域名
    正确识别希捷Backup Plus新睿品1TB正品,杜绝奸商猖獗
  • 原文地址:https://www.cnblogs.com/qqandfqr/p/6147440.html
Copyright © 2020-2023  润新知