【问题标题】:jQuery random failing objects without plugin?没有插件的jQuery随机失败对象?
【发布时间】:2012-11-21 10:52:33
【问题描述】:

我正在为假期制作一张贺卡,我想要一些雪花飘落。我不想使用插件来实现这一点。我生成了一些随机在屏幕上放置雪花的代码。我正在尝试使用 for 循环一次在屏幕上随机放置多达 20 个薄片。似乎将 20 个雪花实例放在同一位置。我希望它是随机的。

// 雪花飘落 函数落雪(){

    var snowflake = $('<div class="snowflakes"></div>');
    $('#snowZone').prepend(snowflake);
    snowX = Math.floor(Math.random() * $('#site').width());
    snowSpd = Math.floor(Math.random() + 5000);

    snowflake.css({'left':snowX+'px'});
    snowflake.animate({
        top: "500px",
        opacity : "0",

    }, snowSpd, "easeInCirc", function(){
        $(this).remove();
        fallingSnow();
    });

}
var timer = Math.floor(Math.random() +1000);

window.setInterval(function(){
    fallingSnow();
}, timer);

jsfiddle

【问题讨论】:

    标签: jquery random for-loop jquery-animate setinterval


    【解决方案1】:

    修改元素,而不是修改其类的所有元素。

    function fallingSnow() {
      var snowflake = $('<div class="snowflakes"></div>');
      $('#site').prepend(snowflake);
      snowX = Math.floor(Math.random() * $('#site').width());
      snowSpd = Math.floor(Math.random() * (500) * 20) + 1000;
    
      snowflake.css({
        'left': snowX + 'px'
      });
      snowflake.animate({
        top: "200px", // height of area
        opacity: "0",
    
      }, snowSpd, function() {
        $(this).remove();
        fallingSnow();
      });
    }
    for (var i = 0; i < 100; i++) {
      fallingSnow();
    }
    .snowflakes {
      width: 10px;
      height: 10px;
      background: black;
      position: absolute;
      top: -40px;
    }
    #site {
      width: 400px;
      height: 200px;
      position: relative;
    }
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
    <div id="site"></div>

    【讨论】:

    • 我更新了我的代码,现在两个很多物体同时下落。
    • 一段时间后,多个物体开始同时下落。
    • @NickRivers 删除在fallingSnow() 内的对fallingSnow() 的调用
    • @KevinB 你能不能让它为这个输出摆弄我试过你的例子但是因为 snowCount 没有在任何地方使用
    • 很棒的 +100 凯文提供小提琴。谢谢这是我想要的。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2012-06-15
    • 1970-01-01
    • 1970-01-01
    • 2017-12-13
    • 2014-09-14
    • 2012-08-11
    • 1970-01-01
    相关资源
    最近更新 更多