1

好的,我有两个 jQuery 函数。其中之一是对 div 的简单爆炸效果。另一个函数通过在 div 周围发送粒子来增强爆炸效果。当我单击设置了两个功能的 div 时,它只会触发爆炸效果,而不会触发我网站上带有碎片的功能。

奇怪的东西

在 jsfiddle 中,碎片正在工作而不是爆炸,但在我的网站上,爆炸效果正在发挥作用,但碎片却没有。

这是 jsfiddle 示例:jsfiddle.net/FYB98/3/

注意:我的网站和 jsfiddle 示例都使用相同的 jQuery 版本,即 jquery-1.9.1。

这是我的代码

<style>
.debris {
 display: none;   
 position: absolute;
 width: 28px;
 height: 28px;
 background-color: #ff00ff;
 opacity: 1.0;
 overflow: hidden;
 border-radius: 8px;
}

#bubble {
  position:absolute;
  background-color: #ff0000;
  left:150px;
  top:150px;
  width:32px;
  height:32px;
  border-radius: 8px;
  z-index: 9;
}
</style>
<div id="content">
    <div id="bubble"></div>
    <div id="dummy_debris" class="debris" />
</div>
<script>
// jQuery bubble pop animation
// Ben Ridout (c) 2013 - http://BenRidout.com/?q=bubblepop
// You're free to use this code with above attribution (in source is fine).

$(function(){
  // Document is ready
  $("#bubble").on("click", function(e) {
    pop(e.pageX, e.pageY, 13);
  });
});
 $( "#bubble" ).click(function() {
  $( this ).toggle( "explode", {pieces: 50 }, 2000);

});
function r2d(x) {
    return x / (Math.PI / 180);
  }

  function d2r(x) {
    return x * (Math.PI / 180);
  }

  function pop(start_x, start_y, particle_count) {
    arr = [];
    angle = 0;
    particles = [];
    offset_x = $("#dummy_debris").width() / 2;
    offset_y = $("#dummy_debris").height() / 2;

    for (i = 0; i < particle_count; i++) {
      rad = d2r(angle);
      x = Math.cos(rad)*(80+Math.random()*20);
      y = Math.sin(rad)*(80+Math.random()*20);
      arr.push([start_x + x, start_y + y]);
      z = $('<div class="debris" />');
      z.css({
          "left": start_x - offset_x,
          "top": start_y - offset_x
      }).appendTo($("#content"));
      particles.push(z);
      angle += 360/particle_count;
    }

    $.each(particles, function(i, v){
      $(v).show();
      $(v).animate(
        {
          top: arr[i][1], 
          left: arr[i][0],
          width: 4, 
          height: 4, 
          opacity: 0
        }, 600, function(){$(v).remove()
      });
    });
  }
</script>
4

2 回答 2

5

从您的小提琴看来,您似乎错过了包含jQuery UI.

检查这个小提琴

于 2013-08-07T18:14:28.653 回答
0

您还没有在$(function)处理程序中放置第二次单击事件。将两个事件都放在$(function)处理程序中

$(function(){
  // Document is ready
  $("#bubble").on("click", function(e) {
    pop(e.pageX, e.pageY, 13);
  });

$( "#bubble" ).click(function() {
  $( this ).toggle( "explode", {pieces: 50 }, 2000);

});
});

工作演示:http: //jsfiddle.net/FYB98/9/

于 2013-08-07T18:16:11.503 回答