jQuery: eliminate white screen “pause” between animations

后端 未结 3 1162
陌清茗
陌清茗 2020-12-11 09:54

I have just discovered Barba.js and find it very useful. It provides smooth transitions between URLs of the same website.

I have put together a

相关标签:
3条回答
  • 2020-12-11 10:31

    The white screen is the body color because you're using promise().done(..) jquery apply the fadeIn after the fadeOut finish so the body color will appear. So, this is an example sort of similar to what you have:

    <style type="text/css">
        .One{
            width: 100%;
            height: 100%;
            position: absolute;
            margin: 0px;
            padding: 0px;
            top: 0px;
            left: 0px;
            background-color: #476d80;
            cursor: pointer;
            z-index: 1;
        }
        .Two{
            width: 100%;
            height: 100%;
            position: absolute;
            margin: 0px;
            padding: 0px;
            top: 0px;
            left: 0px;
            background-color: #03A9F4;
            cursor: pointer;
            display: none;
        }
    </style>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
    <script type="text/javascript">
        $(document).ready(function(){
            $('div.one').click(function(){
                $(this).fadeOut(1000).promise().done(function(){
                    $('div.Two').fadeIn(1000);
                });
            });
        });
    </script>
    <div class="One"></div>
    <div class="Two"></div>
    

    like you see in the example above the white screen also appears so if you don't want that just don't use promise().done(..).

    $(document).ready(function(){
        $('div.one').click(function(){
            $(this).fadeOut(1000);
            $('div.Two').fadeIn(1000);
        });
    });
    

    you can edit your code like this:

    $(this.oldContainer).fadeOut(1000).promise().done(() => {
        $('html, body').animate({
            scrollTop: 300
        },1000);
    });
    nc.css('visibility', 'visible');
    nc.fadeIn(1000, function() {
        _this.done();
    });
    
    0 讨论(0)
  • 2020-12-11 10:36

    How about using setTimeout() to overlap the fade out and fade in? That should keep it from blanking out completely, which want to avoid.

    You could try something like the following:

    $(document).ready(function() {
      var transEffect = Barba.BaseTransition.extend({
        start: function() {
          this.newContainerLoading.then(val => this.fadeInNewcontent($(this.newContainer)));
        },
        fadeInNewcontent: function(nc) {
          nc.hide();
          var _this = this;
    
          // manipulate these values
          let fadeOutTime = 1000;
          let fadeInTime = 1000;
          let overlapTime = 100;
    
          $(this.oldContainer).fadeOut(fadeOutTime);
    
          // use setTimeout() to begin fadeIn before fadeOut is completely done
          setTimeout(function () {
            nc.css('visibility', 'visible');
            nc.fadeIn(fadeInTime, function() {
              _this.done();
            });
    
            $('html, body').animate({
              scrollTop: 300
            }, fadeInTime);
    
          }, fadeOutTime - overlapTime)
    
        }
      });
      Barba.Pjax.getTransition = function() {
        return transEffect;
      }
      Barba.Pjax.start();
    });
    

    NOTE: This is just a stab at it, the plunker is helpful, but it's hard to see the animation in action.

    UPDATE

    I think you'll need something like the above, but if you want to fade in/out of black, then you'll also want to do something like create a div wrapper around all of your content within your body and give that div the background color of your app, #eff3f6, and then making the actual body background black. You'll have some work to get the exact effect you desire, but something like that or in the SO link in the comments below should help.

    0 讨论(0)
  • 2020-12-11 10:38

    I came out with this version of the script:

    $(function(){
        var transEffect = Barba.BaseTransition.extend({
        start: function() {
          this.newContainerLoading.then(val => this.fadeInNewcontent($(this.newContainer)));
        },
        fadeInNewcontent: function(nc) {
          var _this = this;
          nc.css('visibility', 'visible');
          nc.show().promise().done(() => {
            $(this.oldContainer).fadeOut(50);
            if (!isMobile.any()) {
              $('html, body').delay(100).animate({
                scrollTop: 200
              },700);
            }
          });
        }
      });
      Barba.Pjax.getTransition = function() {
        return transEffect;
      }
      Barba.Pjax.start();
    });
    

    It is better, but not smooth enough. See the the effect on a real life project. How can I improve it?

    0 讨论(0)
提交回复
热议问题