RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1000603
Accepted
Александр
Александр
Asked:2020-07-08 20:38:32 +0000 UTC2020-07-08 20:38:32 +0000 UTC 2020-07-08 20:38:32 +0000 UTC

光滑+动画哇js

  • 772

有一个水平站点可以通过 slick 工作并以块为基础工作。滚动到下一张幻灯片时,必须启动该幻灯片上元素的动画(facts-item-hint)。这是它应该如何工作的一个清晰示例https://lore1ei.github.io/第一张幻灯片上一切都很好,第二张幻灯片与第一张幻灯片一起启动,但它应该只在它位于浏览器窗口的可见性。

    <section class="slider">
        <article class="slider_item">
    <div class="header">
        <div class="wraper">
            <div class="logo">
                <img src="img/logo.png" alt="logo">
                <h1>SM-Marketing</h1>
            </div>
            <div class="first-page">
                <div class="method">
                    <h2>Методика №1</h2>
                    <p class="title-p" >по скоростному получению клиентов из интернета</p>
                    <p class="method-p">или <br> как с полного нуля, <br> всего через пару дней <br> начать получать первые заявки</p>
                </div>
                <div class="block-jq">
                    <div class="block-jq-item wow bounceInDown"><div>как найти новых клиентов</div></div>
                    <div class="block-jq-item wow bounceInRight"><div>как получать больше заявок</div></div>
                    <div class="block-jq-item wow bounceInUp"><div>как построить систему лидогенерации</div></div>
                </div>
            </div>
        </div>
    </div>
</article>
<article class="slider_item">
    <div class="facts">
        <div class="wraper wrap100">
            <div class="facts-item">
                <h2>Факт №1</h2>
                <div class="facts-item-hint wow bounceInDown" >Заявки  это сырьё для продаж <br>
                    Не будет заявок – не будет и продаж</div>
            </div>
            <div class="facts-item">
                <h2>Факт №2</h2>
                <div class="facts-item-hint wow bounceInDown" >Прямо сейчас ваши конкуренты используют маркетинговые <br>
                    инструментыи поэтому у них всё впорядке с клиентами </div>
            </div>
        </div>
    </div>
</article>
    </section>

这是滑块的css

.slider 
    width: 100%
    height: 100vh

.slick-list,
.slick-track 
    width: 100%
    height: 100%

.slider__item 
    width: 100%
    height: 100%

这是网站本身在滑块上的工作方式

$(function () {
    $('.slider').slick({
      infinite: false,
      arrows: false
    });

    $('.slider').mousewheel(function (e) {
      if (e.deltaY !== 1) {
        $('.slider').slick('slickNext');
      } else {
        $('.slider').slick('slickPrev');
      }

      e.preventDefault();
    });
  });

我尝试在垂直滚动时使用偏移,它工作正常,但在水平滚动时,所有元素都会立即启动动画。

<script>
        new WOW({
                offset: 100 }).init();
</script>
javascript
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. Best Answer
    HamSter
    2020-07-09T01:04:52Z2020-07-09T01:04:52Z

    原文在这里-codepen.io/joxxce

    滑块的示例:

    $('.slider').on('init', function(e, slick) {
      var $firstEl = $('.slider_item:first-child').find('[data-animation]');
      doAnimation($firstEl);    
    });
    $('.slider').on('beforeChange', function(e, slick, currentSlide, nextSlide) {
      var $animationEl = $('.slider_item[data-slick-index="' + nextSlide + '"]').find('[data-animation]');
      doAnimation($animationEl);    
    });
    
    $('.slider').slick({
      infinite: false,
      arrows: false,
    });
    
    
    $('.slider').mousewheel(function (e) {
      if (e.deltaY !== 1) {
        $('.slider').slick('slickNext');
      } else {
        $('.slider').slick('slickPrev');
      }
    
      e.preventDefault();
    });
    
    
    function doAnimation(elements) {
      var animationEndEvents = 'webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend';
      elements.each(function() {
        var $this = $(this);
        var $animationDelay = $this.data('delay');
        var $animationType = 'animated ' + $this.data('animation');
        $this.css({
          'animation-delay': $animationDelay,
          '-webkit-animation-delay': $animationDelay
        });
        $this.addClass($animationType).one(animationEndEvents, function() {
          $this.removeClass($animationType);
        });
      });
    }
    
    // new WOW({
    //   offset: 100 
    // }).init();
    * {
      box-sizing: border-box;
    }
    
    html,
    body {
      padding: 0;
      margin: 0;
    
      width: 100%;
      height: 100%;
    }
    
    .slider,
    .slick-list,
    .slick-track,
    .slider__item {
      width: 100%;
        height: 100vh;
    }
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/animate.css/3.7.2/animate.min.css" />
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/jquery.slick/1.5.7/slick.css" />
    <script src="https://cdn.jsdelivr.net/jquery.slick/1.5.7/slick.min.js" ></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/wow/1.1.2/wow.min.js" ></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-mousewheel/3.1.13/jquery.mousewheel.min.js" ></script>
    
    <section class="slider">
    
      <article class="slider_item">
        <div class="header">
          <div class="wraper">
            <div class="logo">
              <img src="img/logo.png" alt="logo">
              <h1>SM-Marketing</h1>
            </div>
            <div class="first-page">
              <div class="method">
                <h2>Методика №1</h2>
                <p class="title-p" >по скоростному получению клиентов из интернета</p>
                <p class="method-p">или <br> как с полного нуля, <br> всего через пару дней <br> начать получать первые заявки</p>
              </div>
              <div class="block-jq">
                <div class="block-jq-item" data-animation="bounceInDown" data-delay="0.3s"><div>как найти новых клиентов</div></div>
                <div class="block-jq-item" data-animation="bounceInRight" data-delay="0.3s"><div>как получать больше заявок</div></div>
                <div class="block-jq-item" data-animation="bounceInUp" data-delay="0.3s"><div>как построить систему лидогенерации</div></div>
              </div>
            </div>
          </div>
        </div>
      </article>
    
      <article class="slider_item">
        <div class="facts">
          <div class="wraper wrap100">
            <div class="facts-item">
              <h2>Факт №1</h2>
              <div class="facts-item-hint" data-animation="bounceInDown" data-delay="0.3s">Заявки  это сырьё для продаж <br>
                Не будет заявок – не будет и продаж</div>
            </div>
            <div class="facts-item">
              <h2>Факт №2</h2>
              <div class="facts-item-hint" data-animation="bounceInDown" data-delay="0.3s">Прямо сейчас ваши конкуренты используют маркетинговые <br>
                инструментыи поэтому у них всё впорядке с клиентами </div>
            </div>
          </div>
        </div>
      </article>
    </section>

    底线是这里没有使用 wow 插件,而只使用了 animate.css。

    • 3
  2. Облачное Хранилище
    2022-06-04T18:02:24Z2022-06-04T18:02:24Z

    CodePen Ready slick-slider + wow.js 示例

    function animateSlider(elements){
      var animationEndEvents = 'webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend';
      elements.each(function(){
        var $this = $(this);
        var $animationType = 'animated ' + $this.data('animation');
        $this.addClass($animationType).one(animationEndEvents, function() {
          $this.removeClass($animationType);
        });
      })
    }
    $("#animation-slider").on("beforeChange", function(e, slick, currentSlide, nextSlide) {
      var $animatingElements = $('.slick-slide[data-slick-index="' + nextSlide + '"]').find('[data-animation]');
      animateSlider($animatingElements);    
    })
    $('#animation-slider').on('init', function(e, slick) {
      var $firstAnimatingElements = $('.slick-slide:first-child').find('[data-animation]');
      animateSlider($firstAnimatingElements);    
    });
    $('.hero-carousel').slick({
      infinite: true,
      slidesToShow: 1,
      slidesToScroll: 1,
      dots: true,
      arrows: true,
      speed: 300,
      fade: true,
      cssEase: 'linear',
      // autoplay: true,
      // autoplaySpeed: 3000,
    });
    .hero-carousel__item
      border: 1px solid black
      text-align: center
      padding: 20px
    .hero-carousel#animation-slider
      .hero-carousel__item
        h1(data-animation="fadeInDown" data-delay="0.3s") Пример анимации
        .buttin(data-animation="fadeInUp" data-delay="0.3s")
          button Кнопка
      .hero-carousel__item
        h1(data-animation="fadeInDown" data-delay="0.3s") Пример анимации
        .buttin(data-animation="fadeInUp" data-delay="0.3s")
          button Кнопка
      .hero-carousel__item
        h1(data-animation="fadeInDown" data-delay="0.3s") Пример анимации
        .buttin(data-animation="fadeInUp" data-delay="0.3s")
          button Кнопка
      .hero-carousel__item
        h1(data-animation="fadeInDown" data-delay="0.3s") Пример анимации
        .buttin(data-animation="fadeInUp" data-delay="0.3s")
          button Кнопка

    • 0

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    根据浏览器窗口的大小调整背景图案的大小

    • 2 个回答
  • Marko Smith

    理解for循环的执行逻辑

    • 1 个回答
  • Marko Smith

    复制动态数组时出错(C++)

    • 1 个回答
  • Marko Smith

    Or and If,elif,else 构造[重复]

    • 1 个回答
  • Marko Smith

    如何构建支持 x64 的 APK

    • 1 个回答
  • Marko Smith

    如何使按钮的输入宽度?

    • 2 个回答
  • Marko Smith

    如何显示对象变量的名称?

    • 3 个回答
  • Marko Smith

    如何循环一个函数?

    • 1 个回答
  • Marko Smith

    LOWORD 宏有什么作用?

    • 2 个回答
  • Marko Smith

    从字符串的开头删除直到并包括一个字符

    • 2 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5