动态容纳容器中的碰撞元素

时间:2017-01-27 00:56:55

标签: javascript jquery css jquery-collision

我绝对定位了从数据库生成的不同position.topheight的元素。

我所要做的就是在调整宽度以适应<body>容器内时,将它们向右移动来解除碰撞这些元素。

我在将“左”位置应用于碰撞元素时遇到问题。

我使用https://sourceforge.net/projects/jquerycollision/来检测碰撞。

以下是最终图片的外观:

screenshot

$('div').each(function() {
  var name = $(this).text();
  var hits = $(this).collision('div').not(this); // Find colliding elements
  console.log(name + ' collides with: ' + hits.length + ' others');

  if (hits.length > 0) {
    var widthAll = 100 / (hits.length + 1);

    // Shift colliding elements to the right with equal width
    $(hits).add(this).each(function(i) {
      var name = $(this).text();
      $(this).css({ 'left': widthAll * i + '%', 'width': widthAll + '%' });
    });
  }
});
div {
  position: absolute;
  width: 10em;
  font-size: 0.75em;
  color: white;
}

.blue {
  top: 0;
  height: 80%;
  background-color: blue;
}

.red {
  top: 15%;
  height: 5%;
  background-color: red;
}

.yellow {
  top: 17%;
  height: 10%;
  background-color: yellow;
  color: black;
}

.green {
  top: 30%;
  height: 5%;
  background-color: green;
}

.magenta {
  top: 36%;
  height: 3%;
  background-color: magenta;
}

.cyan {
  top: 50%;
  height: 5%;
  background-color: cyan;
  color: black;
}

.brown {
  top: 81%;
  height: 5%;
  background-color: brown;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script src="https://rawgit.com/dsbaars/jquery-collision/master/js/jquery-collision.min.js"></script>

<div class='blue'>blue</div>
<div class='red'>red</div>
<div class='yellow'>yellow</div>
<div class='green'>green</div>
<div class='magenta'>magenta</div>
<div class='cyan'>cyan</div>
<div class='brown'>brown</div>

1 个答案:

答案 0 :(得分:1)

我想我已按您的要求完成了您的代码。这个想法是,

  1. 第一个代码块将div向右移动,使它们不重叠。
  2. 第二个块使div的宽度根据身体的大小均匀分布。
  3. 最后一个块增加div的其余部分的宽度以占用剩余空间。
  4. "use strict";
    var divs = $('div'),
      mx = 0,
      mxs = [0],
      bw = $("body").outerWidth(),
      steps = 1;
    divs.each(function(i) {
      for (var j = i + 1; j < divs.length; j++) {
        if (!$(this).data("x")) $(this).data("x", 0);
        if (j < divs.length) {
          var hit = $(this).collision(divs[j]);
          if (hit.length) {
            hit = $(divs[j]);
            hit.css("left", "+=" + Math.ceil($(this).outerWidth()));
            hit.data("x", hit.position().left);
            if (mx < hit.data("x")) {
              mxs.push(mx = hit.data("x"));
              steps++;
            }
          }
        }
      }
    });
    
    divs.each(function(i) {
      let iw = $(this).outerWidth(),
        fw = bw / steps;
      $(this).outerWidth(fw);
      for (var j = i + 1; j < divs.length; j++) {
        $(this).collision(divs[j]).css("left", "+=" + Math.ceil((fw - iw) * mxs.indexOf($(divs[j]).data("x"))));
      }
    });
    divs.each(function() {
      var os = $(this).outerWidth(),
        ts = bw - $(this).position().left;
      $(this).outerWidth(ts);
      if ($(this).collision(divs).not(this).length) {
        $(this).outerWidth(os);
      }
    });
    body {
      margin: 0;
    }
    div {
      position: absolute;
      width: 10em;
      font-size: 0.75em;
      color: white;
      left: 0;
    }
    .blue {
      top: 0;
      height: 80%;
      background-color: blue;
    }
    .red {
      top: 15%;
      height: 5%;
      background-color: red;
    }
    .yellow {
      top: 17%;
      height: 10%;
      background-color: yellow;
      color: black;
    }
    .green {
      top: 20%;
      height: 50%;
      background-color: green;
    }
    .magenta {
      top: 36%;
      height: 3%;
      background-color: magenta;
    }
    .cyan {
      top: 50%;
      height: 5%;
      background-color: cyan;
      color: black;
    }
    .brown {
      top: 81%;
      height: 5%;
      background-color: brown;
    }
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <script src="https://rawgit.com/dsbaars/jquery-collision/master/js/jquery-collision.min.js"></script>
    
    <div class='blue'>blue</div>
    <div class='red'>red</div>
    <div class='yellow'>yellow</div>
    <div class='green'>green</div>
    <div class='magenta'>magenta</div>
    <div class='cyan'>cyan</div>
    <div class='brown'>brown</div>

    以上代码段无响应。如果您希望它具有响应性,那么只需听取调整大小事件,更改bw的值并重复代码块2和3.

    正如评论中所述: jquery-collision.min.js有一些未解决的错误,因此,正如 Alex G 建议的那样,https://www.48design.de/de/news/2009/11/20/kollisionsabfrage-per-jquery-plugin-update-v11/可能是替代品。