为 div 制作动画并使其滑落

发布于 2024-11-16 16:00:09 字数 2074 浏览 4 评论 0原文

作为新的 jQuery,我无法组合代码来使 div 动画从左侧到右侧,然后向下滑动。滑动之前 div 的高度约为 10px,然后滑动到其全高 351px。 我可以设法单独执行上述操作,但不能组合执行!希望能得到一点指导,谢谢。 这是我当前的代码;

$.hideAllExcept = function(tabs,boxes){
function init() {

  // make it bookmarkable/refreshable. but, no history.
  var hash = window.location.hash;
  (!hash) ? hideShow('#' + $(boxes+':first').attr('id')) : hideShow(window.location.hash);

  // add click handler.

  $(tabs).click(function(e) {
    e.preventDefault();
    var href = $(this).attr('href');
    // add back the hash which is prevented by e.preventDefault()
    window.location.hash = href;
    hideShow(href);
  });
}

function hideShow(el) {


    $(boxes).animate({"left": "-650px"}, "slow");
     $(el).fadeIn('slow').animate({"left" : "60%",height:"351" }, 1000);

$(tabs).removeClass('active');
      $('a[href="' + el + '"]').addClass('active');
    }
    init();

};

取得了一点进步!! 我已经让它在临时服务器上运行:

http://www. tridentsolutions.co.nz/test-folder/index.html#construction_home

但我无法让框返回 LHS 也无法查看文本的可见性,因为文本位于 html 中而不是图像在 div 中,这是否意味着我无法隐藏文本? 提前致谢

(function($){

$.hideAllExcept = function(tabs,boxes){
    function init() {

      // make it bookmarkable/refreshable. but, no history.
      var hash = window.location.hash;
      (!hash) ? hideShow('#' + $(boxes+':first').attr('id')) : hideShow(window.location.hash);

      // add click handler.

      $(tabs).click(function(e) {
        e.preventDefault();
        var href = $(this).attr('href');
        // add back the hash which is prevented by e.preventDefault()
        window.location.hash = href;
        hideShow(href);
      });
    }

 function hideShow(el) {

     $(el).animate({"left": "-650px"}, "slow").fadeIn('slow');
    $(el).fadeIn('slow').animate({"left" : "60%" }, 1000).animate({"height" : "351" }, 1000);


$(tabs).removeClass('active');
      $('a[href="' + el + '"]').addClass('active');
    }
    init();

};

Being new jQuery I having trouble combining the code to have a div animate from the left hand side to the right and then slidedown. The height of the div before slidedown would be about 10px then slidedown to it's full height 351px.
I can manage to do the above separately but not combined!! Would appreciate a little guidance please, thanks.
This is my current code;

$.hideAllExcept = function(tabs,boxes){
function init() {

  // make it bookmarkable/refreshable. but, no history.
  var hash = window.location.hash;
  (!hash) ? hideShow('#' + $(boxes+':first').attr('id')) : hideShow(window.location.hash);

  // add click handler.

  $(tabs).click(function(e) {
    e.preventDefault();
    var href = $(this).attr('href');
    // add back the hash which is prevented by e.preventDefault()
    window.location.hash = href;
    hideShow(href);
  });
}

function hideShow(el) {


    $(boxes).animate({"left": "-650px"}, "slow");
     $(el).fadeIn('slow').animate({"left" : "60%",height:"351" }, 1000);

$(tabs).removeClass('active');
      $('a[href="' + el + '"]').addClass('active');
    }
    init();

};

made a little progress!!
I've got it running on a temp server:

http://www.tridentsolutions.co.nz/test-folder/index.html#construction_home

But I can't get the boxes to return to the LHS also see how the text is visible, as the text is in the html and not an image in the div, does that mean I can't hide the text?
Thanks in advance

(function($){

$.hideAllExcept = function(tabs,boxes){
    function init() {

      // make it bookmarkable/refreshable. but, no history.
      var hash = window.location.hash;
      (!hash) ? hideShow('#' + $(boxes+':first').attr('id')) : hideShow(window.location.hash);

      // add click handler.

      $(tabs).click(function(e) {
        e.preventDefault();
        var href = $(this).attr('href');
        // add back the hash which is prevented by e.preventDefault()
        window.location.hash = href;
        hideShow(href);
      });
    }

 function hideShow(el) {

     $(el).animate({"left": "-650px"}, "slow").fadeIn('slow');
    $(el).fadeIn('slow').animate({"left" : "60%" }, 1000).animate({"height" : "351" }, 1000);


$(tabs).removeClass('active');
      $('a[href="' + el + '"]').addClass('active');
    }
    init();

};

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

不奢求什么 2024-11-23 16:00:09

您是否尝试过将两种效果链接在一起?将它们分成两个 animate() 函数,然后按照您想要的顺序链接它们:

$(el).fadeIn('slow').animate({"left" : "60%"}, 1000).animate({"height:"351" }, 1000);

每个 animate() 函数都按顺序运行,因此您可以一个接一个地执行任意数量的效果。

Have you tried chaining the two effects together? Break them up into two animate() functions and then chain them in the order you want:

$(el).fadeIn('slow').animate({"left" : "60%"}, 1000).animate({"height:"351" }, 1000);

Each animate() function runs in sequence, so you can do any number of effects one after the other.

日暮斜阳 2024-11-23 16:00:09

如果您希望一个动画在另一个动画完成后触发,请使用 .animate 的回调:

伪代码:

$(selector).animate({ key: val },
                     'slow' /*easing*/,
                      function() {
                          // second animation goes here
                     });

If you want one animation to fire after another finishes, use the .animate's callback:

pseudo-ish code:

$(selector).animate({ key: val },
                     'slow' /*easing*/,
                      function() {
                          // second animation goes here
                     });
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文