单击2次后单击功能正在运行

时间:2015-07-25 13:50:34

标签: jquery function click

我写了一个小脚本,但是没有用。 我想点击按钮后启动一个功能。但我的脚本需要两次点击。有时它需要多次点击。 我有什么要修改它在第一次点击后开始工作?

if (!onGround){

        playerVisual.setY(playerVisual.getY() + this.gravity);

    }

    if (playerVisual.getY() >= this.main.getDevice().getHeight() - 10){
        this.onGround = true;
    }
    else {
        this.onGround = false;
    }
$('#hotelfilter').click(function(){    
    $('#hotel').fadeOut('slow', 
    function(){
        $('#gastro').fadeIn();
    });
	$('#hotelnav').fadeOut('slow', 
    function(){
        $('#gastronav').fadeIn();
    });
	$.scrollTo('.gastro1', 1000);
return false;
});

$('#gastrofilter').click(function(){    
    $('#gastro').fadeOut('slow', 
    function(){
        $('#hotel').fadeIn();
    });
	$('#gastronav').fadeOut('slow', 
    function(){
        $('#hotelnav').fadeIn();
    });
	
		$.scrollTo('.hotel1', 1000);
	return false;
	
});

/*!
 * jQuery.ScrollTo
 * Copyright (c) 2007-2014 Ariel Flesler - aflesler<a>gmail<d>com | http://flesler.blogspot.com
 * Licensed under MIT
 * http://flesler.blogspot.com/2007/10/jqueryscrollto.html
 * @projectDescription Easy element scrolling using jQuery.
 * @author Ariel Flesler
 * @version 1.4.12
 */

;
(function(plugin) {
  // AMD Support
  if (typeof define === 'function' && define.amd) {
    define(['jquery'], plugin);
  } else {
    plugin(jQuery);
  }
}(function($) {

  var $scrollTo = $.scrollTo = function(target, duration, settings) {
    return $(window).scrollTo(target, duration, settings);
  };

  $scrollTo.defaults = {
    axis: 'xy',
    duration: parseFloat($.fn.jquery) >= 1.3 ? 0 : 1,
    limit: true
  };

  // Returns the element that needs to be animated to scroll the window.
  // Kept for backwards compatibility (specially for localScroll & serialScroll)
  $scrollTo.window = function(scope) {
    return $(window)._scrollable();
  };

  // Hack, hack, hack :)
  // Returns the real elements to scroll (supports window/iframes, documents and regular nodes)
  $.fn._scrollable = function() {
    return this.map(function() {
      var elem = this,
        isWin = !elem.nodeName || $.inArray(elem.nodeName.toLowerCase(), ['iframe', '#document', 'html', 'body']) != -1;

      if (!isWin)
        return elem;

      var doc = (elem.contentWindow || elem).document || elem.ownerDocument || elem;

      return /webkit/i.test(navigator.userAgent) || doc.compatMode == 'BackCompat' ?
        doc.body :
        doc.documentElement;
    });
  };

  $.fn.scrollTo = function(target, duration, settings) {
    if (typeof duration == 'object') {
      settings = duration;
      duration = 0;
    }
    if (typeof settings == 'function')
      settings = {
        onAfter: settings
      };

    if (target == 'max')
      target = 9e9;

    settings = $.extend({}, $scrollTo.defaults, settings);
    // Speed is still recognized for backwards compatibility
    duration = duration || settings.duration;
    // Make sure the settings are given right
    settings.queue = settings.queue && settings.axis.length > 1;

    if (settings.queue)
    // Let's keep the overall duration
      duration /= 2;
    settings.offset = both(settings.offset);
    settings.over = both(settings.over);

    return this._scrollable().each(function() {
      // Null target yields nothing, just like jQuery does
      if (target == null) return;

      var elem = this,
        $elem = $(elem),
        targ = target,
        toff, attr = {},
        win = $elem.is('html,body');

      switch (typeof targ) {
        // A number will pass the regex
        case 'number':
        case 'string':
          if (/^([+-]=?)?\d+(\.\d+)?(px|%)?$/.test(targ)) {
            targ = both(targ);
            // We are done
            break;
          }
          // Relative/Absolute selector, no break!
          targ = win ? $(targ) : $(targ, this);
          if (!targ.length) return;
        case 'object':
          // DOMElement / jQuery
          if (targ.is || targ.style)
          // Get the real position of the target
            toff = (targ = $(targ)).offset();
      }

      var offset = $.isFunction(settings.offset) && settings.offset(elem, targ) || settings.offset;

      $.each(settings.axis.split(''), function(i, axis) {
        var Pos = axis == 'x' ? 'Left' : 'Top',
          pos = Pos.toLowerCase(),
          key = 'scroll' + Pos,
          old = elem[key],
          max = $scrollTo.max(elem, axis);

        if (toff) { // jQuery / DOMElement
          attr[key] = toff[pos] + (win ? 0 : old - $elem.offset()[pos]);

          // If it's a dom element, reduce the margin
          if (settings.margin) {
            attr[key] -= parseInt(targ.css('margin' + Pos)) || 0;
            attr[key] -= parseInt(targ.css('border' + Pos + 'Width')) || 0;
          }

          attr[key] += offset[pos] || 0;

          if (settings.over[pos])
          // Scroll to a fraction of its width/height
            attr[key] += targ[axis == 'x' ? 'width' : 'height']() * settings.over[pos];
        } else {
          var val = targ[pos];
          // Handle percentage values
          attr[key] = val.slice && val.slice(-1) == '%' ?
            parseFloat(val) / 100 * max : val;
        }

        // Number or 'number'
        if (settings.limit && /^\d+$/.test(attr[key]))
        // Check the limits
          attr[key] = attr[key] <= 0 ? 0 : Math.min(attr[key], max);

        // Queueing axes
        if (!i && settings.queue) {
          // Don't waste time animating, if there's no need.
          if (old != attr[key])
          // Intermediate animation
            animate(settings.onAfterFirst);
          // Don't animate this axis again in the next iteration.
          delete attr[key];
        }
      });

      animate(settings.onAfter);

      function animate(callback) {
        $elem.animate(attr, duration, settings.easing, callback && function() {
          callback.call(this, targ, settings);
        });
      };

    }).end();
  };

  // Max scrolling position, works on quirks mode
  // It only fails (not too badly) on IE, quirks mode.
  $scrollTo.max = function(elem, axis) {
    var Dim = axis == 'x' ? 'Width' : 'Height',
      scroll = 'scroll' + Dim;

    if (!$(elem).is('html,body'))
      return elem[scroll] - $(elem)[Dim.toLowerCase()]();

    var size = 'client' + Dim,
      html = elem.ownerDocument.documentElement,
      body = elem.ownerDocument.body;

    return Math.max(html[scroll], body[scroll]) - Math.min(html[size], body[size]);
  };

  function both(val) {
    return $.isFunction(val) || typeof val == 'object' ? val : {
      top: val,
      left: val
    };
  };

  // AMD requirement
  return $scrollTo;
}));
section {
  height: 100px;
  background-color: #FF0000;
}
footer {
  height: 200px;
}
.hotel1,
.hotel3,
.hotel5,
.gastro1,
.gastro3,
.gastro5 {
  background-color: #000;
  color: #FFF;
}
#choose {
  height: 500px;
  background: #AAAAFF
}
#gastro {
  display: none;
}

1 个答案:

答案 0 :(得分:0)

问题是隐藏元素没有维度,浏览器也无法计算它们的偏移量。浏览器仅在显示元素时确定

尝试使用fadeIn()动画的回调:

$('#hotelfilter').click(function () {
    $('#hotel').fadeOut('slow', function () {
        $('#gastro').fadeIn(function () {
            // is visible now so we can scroll to it
            $.scrollTo('.gastro1', 1000);
        });
    });
    $('#hotelnav').fadeOut('slow', function () {
        $('#gastronav').fadeIn();
    });

    return false;
});

DEMO