js滚动显示插件scrollappear使用

我们在平时项目中想实现滚动时想在当前屏幕给一些元素来点动画、特殊效果或者其他操作,自己写吧兼容性不好,也浪费开发时间,幸好jquery提供给我们一个scrollappear插件来帮助我们做这些事情,我们只需要简单的根据要求操作即可实现效果,下面我提供一个简单的demo供大家参考。

<!doctype html>
<html>
<head>
    <meta charset="utf-8">
     <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/>
    <title></title>
    <script src="https://cdn.bootcss.com/jquery/1.10.2/jquery.min.js"></script>
    <script src="./js/jquery.appear.js"></script>
    <style type="">
         .move_1{
             position: relative;
             top:-400px;
             opacity: 0; 
         }
         .move_1.go{
            top:50px;
            opacity: 1;
            transition: all 0.6s;
          } 
    </style>
</head>
<body >
<div class=" animatedParent">
    <h3 class="move_1 animated">demo1</h3>
</div>
<div style="height: 1000px;">
</div>
<div class=" animatedParent">
    <h3 class="move_1 animated">demo2</h3>
</div>
<div style="height: 1000px;">
</div>
</body>
</html>
<script>
//添加动画
$('.animatedParent').appear();
$(document.body).on('appear', '.animatedParent', function(e, $affected){
  var ele = $(this).find('.animated');
    ele.addClass('go');
});
 $(document.body).on('disappear', '.animatedParent', function(e, $affected) {
    if(!$(this).hasClass('animateOnce')){
    $(this).find('.animated').removeClass('go');
   }
 });
 $(window).load(function(){
  $.force_appear();
 });    
</script>

解析:
animatedParentanimated是自己定义的但要保证和写的js中对应class保持一致,其中go是滚动到当前屏幕时给指定的元素添加的class。

$(window).load(function(){
  $.force_appear();
 });

上面几行代码当浏览器加载完成后,对当前屏幕需要处理的元素,添加效果。

下面是引用的jquery.appear.js

//jquery.appear.js
/*
 * jQuery appear plugin
 *
 * Copyright (c) 2012 Andrey Sidorov
 * licensed under MIT license.
 *
 * https://github.com/morr/jquery.appear/
 *
 * Version: 0.3.3
 */
(function($) {
  var selectors = [];

  var check_binded = false;
  var check_lock = false;
  var defaults = {
    interval: 250,
    force_process: false
  }
  var $window = $(window);

  var $prior_appeared;

  function process() {
    check_lock = false;
    for (var index = 0; index < selectors.length; index++) {
      var $appeared = $(selectors[index]).filter(function() {
        return $(this).is(':appeared');
      });

      $appeared.trigger('appear', [$appeared]);

      if ($prior_appeared) {
        var $disappeared = $prior_appeared.not($appeared);
        $disappeared.trigger('disappear', [$disappeared]);
      }
      $prior_appeared = $appeared;
    }
  }

  // "appeared" custom filter
  $.expr[':']['appeared'] = function(element) {
    var $element = $(element);
    if (!$element.is(':visible')) {
      return false;
    }

    var window_left = $window.scrollLeft();
    var window_top = $window.scrollTop();
    var offset = $element.offset();
    var left = offset.left;
    var top = offset.top;

    if (top + $element.height() >= window_top &&
        top - ($element.data('appear-top-offset') || 0) <= window_top + $window.height() &&
        left + $element.width() >= window_left &&
        left - ($element.data('appear-left-offset') || 0) <= window_left + $window.width()) {
      return true;
    } else {
      return false;
    }
  }

  $.fn.extend({
    // watching for element's appearance in browser viewport
    appear: function(options) {
      var opts = $.extend({}, defaults, options || {});
      var selector = this.selector || this;
      if (!check_binded) {
        var on_check = function() {
          if (check_lock) {
            return;
          }
          check_lock = true;

          setTimeout(process, opts.interval);
        };

        $(window).scroll(on_check).resize(on_check);
        check_binded = true;
      }

      if (opts.force_process) {
        setTimeout(process, opts.interval);
      }
      selectors.push(selector);
      return $(selector);
    }
  });

  $.extend({
    // force elements's appearance check
    force_appear: function() {
      if (check_binded) {
        process();
        return true;
      };
      return false;
    }
  });
})(jQuery);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明AGI阅读 16,017评论 3 119
  • jQuery笔记总结篇 poetries 已关注 2016.10.20 10:52* 字数 9137 阅读 660...
    小杰的简书阅读 1,804评论 2 32
  • 再过两个多月就28岁了,时至今日,知道不少道理,也讲过不少道理,但如今觉得有什么想法去做就好了,鲁莽比恭敬谦虚更来...
    eybook阅读 218评论 0 0
  • 皆空,皆空 什么是空呢 空即色,色即空 那我是空吗 夏温说我还是众生,我还没有涅槃。 什么是涅槃呢? 心无挂碍,无...
    马各马它阅读 95评论 0 0
  • 大学毕业,面临失业。 化学,与生活息息相关,小到穿衣吃饭,大到神舟飞天,哪里用不到化学?偏偏我一个学化学的人正在为...
    alyanliying阅读 297评论 0 0