• vue 中使用 vue-fullpage


    安装并使用

    • 安装
    npm install --save vue-fullpage.js
    
    • 引入
    // 引用fullpage 插件
    import Vue from 'vue'
    import 'fullpage.js/vendors/scrolloverflow' // Optional. When using scrollOverflow:true
    import './fullpage.scrollHorizontally.min' // Optional. When using fullpage extensions
    import VueFullPage from 'vue-fullpage.js'
    
    Vue.use(VueFullPage);
    

    fullpage 配置

    • options
    options: {
            // 为每个section设置背景色
            //sectionsColor: ["#f00","#0f0","#00f"],
            //用来控制slide幻灯片的箭头,设置为false,两侧的箭头会消失
            //controlArrows: false,
            //每一页幻灯片的内容是否垂直居中
            //verticalCentered: false,
            //字体是否随着窗口缩放而缩放
            //resize: true,
            //页面滚动速度
            //scrollingSpeed: 700,
            //定义锚链接,用户可以快速打开定位到某一页面;不需要加"#",不要和页面中任意的id和name相同
            //anchors: ["page1","page2","page3"],
            //是否锁定锚链接
            //lockAnchors: true,
            //定义section页面的滚动方式,需要引入jquery.easings插件
            //easing:,
            //是否使用css3 transform来实现滚动效果
            //css3: false,
            //滚动到最顶部后是否连续滚动到底部
            //loopTop: true,
            //滚动到最底部后是否连续滚动到顶部
            //loopBottom: true,
            //横向slide幻灯片是否循环滚动
            //loopHorizontal: false,
            //是否循环滚动,不会出现跳动,效果很平滑
            //continuousVertical: true,
            //是否使用插件滚动方式,设为false后,会出现浏览器自带的滚动条,将不会按页滚动
            //autoScrolling: false,
            //是否包含滚动条,设为true,则浏览器自带的滚动条会出现,页面还是按页滚动,但是浏览器滚动条默认行为也有效
            //scrollBar: true,
            //设置每个section顶部的padding,当我们要设置一个固定在顶部的菜单、导航、元素等时使用
            //paddingTop: "100px",
            //设置每个section底部的padding,当我们要设置一个固定在底部的菜单、导航、元素等时使用
            //paddingBottom: "100px",
            //固定的元素,为jquery选择器;可用于顶部导航等
            //fixedElements: ".nav",
            //是否可以使用键盘方向键导航
            //keyboardScrolling: false,
            //在移动设置中页面敏感性,最大为100,越大越难滑动
            //touchSensitivity: 5,
            //设为false,则通过锚链接定位到某个页面不再有动画效果
            //animateAnchor: false,
            //是否记录历史,可以通过浏览器的前进后退来导航
            //recordHistory: true,
            //绑定菜单,设定相关属性和anchors的值对应后,菜单可以控制幻灯片滚动
            //menu: '.nav',
            //是否显示导航,设为true会显示小圆点作为导航
            //navigation: true,
            //导航小圆点的位置,可以设置为left或者right
            //navigationPosition: right,
            //鼠标移动到小圆点上时显示出的提示信息
            //navigationTooltips: ["第一页","第二页","第三页"],
            //是否显示当前页面小圆点导航的提示信息,不需要鼠标移上
            //showActiveTooltip: true,
            //是否显示横向幻灯片的导航
            //slidesNavigation: true,
            //横向幻灯片导航的位置,可以为top或者bottom
            //slidesNavPosition: bottom,
            //内容超过满屏时是否显示滚动条,需要jquery.slimscroll插件
            //scrollOverflow: true,
            //section选择器
            //sectionSelector: ".section",
            //slide选择器
            //slideSelector: ".slide"
            licenseKey: 'OPEN-SOURCE-GPLV3-LICENSE',
            afterLoad: this.afterLoad,
            scrollOverflow: true,
            navigation: true, //是否显示导航,默认为false
            navigationPosition: 'right', //导航小圆点的位置
            scrollBar: false,
            keyboardScrolling: false, //是否可以使用键盘方向键导航,默认为true
            continuousVertical: true, /// 是否循环滚动,默认为false。如果设置为true,则页面会循环滚动,而不像loopTop或loopBottom那样出现跳动,注意这个属性和loopTop、loopBottom不兼容和,不要同时设置
            menu: '#menu',
            // navigation: true,
            // anchors: ['page1', 'page2', 'page3'],
            sectionsColor: [
              '#41b883',
              '#ff5f45',
              '#0798ec',
              '#fec401',
              '#1bcee6',
              '#ee1a59',
              '#2c3e4f',
              '#ba5be9',
              '#b4b8ab'
            ]
          }
        };
    

    vue 调用 fullpapge 的方法

    this.$refs.fullpage.api.moveSectionDown();
    this.$refs.fullpage.init();
    
    // 向上滚动一页
    // moveSectionUp();
    //向下滚动一页
    // moveSectionDown();
    //滚动到第几页,第几个幻灯片;页面从1计算,幻灯片从0计算
    // moveTo(wection,slide);
    //和moveTo一样,但是没有动画效果
    // silentMoveTo(section,slide);
    //幻灯片向右滚动
    // moveSlideRight();
    //幻灯片向左滚动
    // moveSlideLeft();
    //动态设置autoScrolling配置项
    // setAutoScrolling(boolean);
    //动态设置lockAnchors配置项
    // setLockAnchors(boolean);
    //动态设置recordHistory配置项
    // setRecordHistory(boolean);
    //动态设置scrollingSpeed配置项
    // setScrollingSpeed(milliseconds);
    //添加或删除鼠标/滑动控制,第一个参数为启用、禁用;第二个参数为方向,取值包含all、up、dowm、left、right,可以使用多个,逗号分隔
    // setAllowScrolling(boolean,[directions]);
    //销毁fullpage特效,不写type,fullpage给页面添加的样式和html元素还在;如果使用all,则样式和html等全部被销毁
    // destroy(type);
    //重新更新页面和尺寸,用于通过ajax请求后改变了页面结构之后,重建效果
    // reBuild();
    

    完整代码

    <template>
      <div>
        <full-page :options="options" id="fullpage" ref="fullpage">
          <div class="section">
            <h3>vue-fullpage.js</h3>
          </div>
          <div class="section">
            <div class="slide">
              <h3>Slide 2.1</h3>
            </div>
            <div class="slide">
              <h3>Slide 2.2</h3>
            </div>
            <div class="slide">
              <h3>Slide 2.3</h3>
            </div>
          </div>
          <div class="section">
            <h3>Section 3</h3>
          </div>
        </full-page>
      </div>
    </template>
    
    <script>
    import { VueExtend } from 'godspen-lib';
    
    export default {
      mixins: [VueExtend.mixin],
      name: 'VueFullPage',
      label: process.env.LABEL,
      style: process.env.STYLE,
      data() {
        return {
          options: {
            licenseKey: 'OPEN-SOURCE-GPLV3-LICENSE',
            afterLoad: this.afterLoad,
            navigation: true,
            anchors: ['page1', 'page2', 'page3'],
            sectionsColor: [
              '#41b883',
              '#ff5f45',
              '#0798ec',
              '#fec401',
              '#1bcee6',
              '#ee1a59',
              '#2c3e4f',
              '#ba5be9',
              '#b4b8ab'
            ]
          }
        };
      },
      methods: {
        afterLoad: function(origin, destination, direction) {
          console.log('After load....');
          console.log(destination);
        }
      }
    };
    </script>
    
    <style lang="stylus" rel="stylesheet/stylus" type="text/stylus" scoped>
    body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote, th, td {
      padding: 0;
      margin: 0;
    }
    
    a {
      text-decoration: none;
    }
    
    table {
      border-spacing: 0;
    }
    
    fieldset, img {
      border: 0;
    }
    
    address, caption, cite, code, dfn, em, strong, th, var {
      font-weight: normal;
      font-style: normal;
    }
    
    strong {
      font-weight: bold;
    }
    
    ol, ul {
      list-style: none;
      margin: 0;
      padding: 0;
    }
    
    caption, th {
      text-align: left;
    }
    
    h1, h2, h3, h4, h5, h6 {
      font-weight: normal;
      font-size: 100%;
      margin: 0;
      padding: 0;
    }
    
    q:before, q:after {
      content: '';
    }
    
    abbr, acronym {
      border: 0;
    }
    
    * {
      -webkit-box-sizing: border-box; /* Safari<=5 Android<=3 */
      -moz-box-sizing: border-box; /* <=28 */
      box-sizing: border-box;
    }
    
    /* Custom
     * --------------------------------------- */
    body {
      font-family: arial, helvetica;
    }
    
    .section {
      position: relative;
      text-align: center;
    }
    
    #section-1 h2 {
      color: #fff;
      font-size: 10em;
      font-weight: 900;
    }
    
    #section-1 h1 {
      font-size: 2em;
      font-weight: 100;
      -webkit-font-smoothing: antialiased;
      -moz-font-smoothing: antialiased;
      margin: 1.5em auto 1em auto;
      color: #35495e;
      padding-right: 30px;
      padding-left: 30px;
    }
    
    #section-1 li {
      display: inline-block;
      margin: 1.25em 0.3em;
    }
    
    .section-1-button {
      padding: 0.93em 1.87em;
      background: #35495e;
      border-radius: 5px;
      display: block;
      color: #fff;
    }
    
    h3 {
      font-size: 5em;
      text-align: center;
      color: #fff;
      font-weight: bold;
    }
    
    #logo {
      position: fixed;
      top: 20px;
      left: 20px;
      color: #fff;
      font-weight: bold;
      z-index: 99;
      font-size: 1.9em;
      -webkit-font-smoothing: antialiased;
      -moz-font-smoothing: antialiased;
    }
    
    /* Menu
     * --------------------------------------- */
    #menu-line {
      position: absolute;
      bottom: -4px;
      left: 0;
       159px;
      height: 2px;
      background: #fff;
    }
    
    #menu {
      position: fixed;
      top: 20px;
      right: 20px;
      z-index: 70;
      -webkit-font-smoothing: antialiased;
      -moz-font-smoothing: antialiased;
      letter-spacing: 1px;
      font-size: 1.1em;
    }
    
    #menu li {
      display: inline-block;
      margin: 10px 0px;
      position: relative;
    }
    
    #menu a {
      color: #fff;
      padding: 0 1.1em 1.1em 1.1em;
    }
    
    #menu li.active a:after {
      content: '';
      margin: 0 1.1em 0 1.1em;
      height: 2px;
      background: #fff;
      display: block;
      position: absolute;
      bottom: -6px;
      left: 0;
      right: 0;
      display: block;
    }
    
    /* Actions buttons
     * --------------------------------------- */
    .actions {
      position: fixed;
      bottom: 2%;
      margin: 0 auto;
      z-index: 99;
      left: 0;
      right: 0;
      text-align: center;
    }
    
    .actions li {
      display: inline-block;
      margin: 0.3em 0.3em;
    }
    
    .actions-button {
      padding: 0.73em 1.47em;
      background: rgba(53, 73, 94, 0.47);
      border-radius: 5px;
      display: block;
      color: #fff;
      cursor: pointer;
    }
    
    /* Twitter
     * --------------------------------------- */
    .twitter-share i {
      vertical-align: middle;
      position: relative;
      top: 2px;
      display: inline-block;
       38px;
      height: 14px;
      color: white;
      top: -4px;
      left: -2px;
      fill: #fff;
    }
    
    .twitter-share svg {
      height: 40px;
      margin-top: -10px;
    }
    
    .view-github {
      position: fixed;
      top: 20px;
      left: 20px;
      z-index: 999;
      padding: 0.93em 1.87em;
      background: #35495e;
      border-radius: 5px;
      display: block;
      color: #fff;
    }
    </style>
    

    doc

  • 相关阅读:
    SetROP2
    FillRect与FrameRect用法
    MFC(继续画图,孙鑫C++第十讲笔记整理)
    海康威视DS-4100、4000HC 系列板卡SDK编程指南
    C--算法与数据结构--顺序表操作
    HTML 5--adding paragraphs
    HTML 5--基础
    temp--文件夹中的文件处理
    Java--蓝桥杯真题(二)
    Java--蓝桥杯真题
  • 原文地址:https://www.cnblogs.com/mybilibili/p/12263820.html
Copyright © 2020-2023  润新知