搜索
您的当前位置:首页fullpage.js的滚屏方式

fullpage.js的滚屏方式

时间:2020-11-27 来源:乌哈旅游
这次给大家带来fullpage.js的滚屏方式,实现fullpage.js的滚屏注意事项有哪些,下面就是实战案例,一起来看一下。

这两天公司网页改版用到fullpage.js这个滚屏插件,页面内容整屏的滚动,不成问题,各种设置在网上也都有文档。
而我遇到的问题就是,页面内容不满屏的时候,和上面的内容放一块就太挤,单独放一屏就太空,好尴尬的说

底部的footer部分就是我要单独处理的部分,从网上搜了各种资料,总结了一下,个人觉着最简单的方法,写一篇文章以便以后查阅。

 <!--footer及倒数第二屏的HTML-->
 <body data-spy="scroll">
 <p id="dowebok" class="container-fluid">
 <p class="section" id="nextS">
 <p class="sect ">
 <p class="sectcenter4"></p>
 </p>
 <p class="sect sectbg2">
 <p class="container">
 <p class="sectcenter5"></p>
 </p>
 </p>
 </p>
 <p class="section footerss"><footer class="footer" id="footer"></footer></p>
 </p>
 </body>
 //初始化滚屏的一些内容,最重要的是设置好锚点,这里重点是最后一屏(footer)的锚点footerl
 $('#dowebok').fullpage({
 verticalCentered: false,
 resize: true,
 navigation: true,
 anchors: ['section-1', 'section-2', 'lastScreen','footerl'],
 });

写完这些,实现的就是下面如图的效果,整个footer占了一屏,并且是垂直居中显示的。

根据要实现的效果,要做的就是让footer紧挨着#nextS这一屏(不垂直居中)+到#nextS这一屏的时候,再往下的滚动距离就不能是一屏了(必须是footer的高度)。
按着整个思路,先解决css的问题

.section.footerss .fp-tableCell{//修改最后一屏display属性
 display: block!important;
 }
//实现footer紧挨着#nextS这一屏显示,底部出现

下面修改fullpage.js的问题,在引用的fullpage.js文件中找到performMovement这个方法,按照如下方法,修改一下,就可以达到想要的效果(footer紧挨着上一屏,并且滚动的高度是footer的height)

function performMovement(v){ 
   // using CSS3 translate functionality 
    if (options.css3 && options.autoScrolling && !options.scrollBar) { 
     if (v.anchorLink == 'footerl'){ //当滚屏到最后一屏时间 
       footer_a = $('#nextS').height();//倒数第二屏的高度 
       footer_h = $('#footer').height(); //footer的高度
        var translate3d = 'translate3d(0px, -' + (v.dtop - footer_a + footer_h) + 'px, 0px)'; 
      }else{ 
       var translate3d = 'translate3d(0px, -' + v.dtop + 'px, 0px)'; 
     } 
     transformContainer(translate3d, true); 
     setTimeout(function () { 
       afterSectionLoads(v); 
     }, options.scrollingSpeed); 
   } 
   // using jQuery animate 
   else{ 
     var scrollSettings = getScrollSettings(v); 
     $(scrollSettings.element).animate( 
       scrollSettings.options 
       , options.scrollingSpeed, options.easing).promise().done(function () { //only one single callback in case of animating `html, body` 
       afterSectionLoads(v); 
      }); 
   } 
 }

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

npm install安装失败怎样解决

Vue枚举类型实现HTML

Top