欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解基于vue-cli3快速發(fā)布一個fullpage組件

 更新時間:2019年03月08日 11:04:58   作者:Yoki  
這篇文章主要介紹了詳解基于vue-cli3快速發(fā)布一個fullpage組件,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前言

想必大家都看過fullpage.js——這是一款非常好用的翻頁插件。

現在vue非常流行,大家想不想發(fā)布一個組件給別人使用呢?

這里我們基于vue-cli3快速搭建一個簡單的fullpage組件給別人使用,當然你也可以做你感興趣的組件發(fā)布給別人用~

GITHUB

鏈接

開始

準備

$ npm i -g @vue/cli #全局vue-cli3

通過查看vue-cli3官網了解,創(chuàng)建一個新的普通項目。

思考

一開始要想別人如何調用我們寫的組件,通過掛載vue實例方法(this.$alert)還是注冊組件。答案自然是后者。我們希望別人可以這么使用~

#一個section塊就是一個可以滾動的塊
<v-fullpage>
 <div slot="section"></div>
 <div slot="section"></div>
</v-fullpage>

設計組件接口,prop??梢杂袧L動方向(垂直還是橫向)

Property Description Type Default
direction 滾動方向('vertical'或'horizontal') String 'vertical'

設計組件的回調(內部需要暴露什么方法給外部)

Name Description
leaveSlide 滑動之后,參數是當前 index

希望可以主動調用內部方法,禁止/開放滾動事件

通過 ref 調用組件內部 api

Name Description
setAllowScrolling 傳入 true/false,禁止?jié)L動/開放滾動事件

目錄結構

├─ dist     //打包
├─ public
├─ src
│ ├─ assets
│ ├─ components  //存放所有 custom elements
│   ├─ fullpage.vue //實際干活的
│ ├─ App.vue  //內部demo,可以引進來我們寫的fullpage組件調試
│ └─ main.js  //入口文件

編寫

我們在fullpage.vue寫邏輯,模板里需要有一個slot(放置別人的div),這個div需要有個滾動盒子包裹(可以通過translate移動)

<div class="v-fullpage-container" ref='v-fullpage'
@mousewheel='mouseWheelHandle'>
//監(jiān)聽鼠標滾輪事件
  <div class="v-slide-container" :class="direction" ref='v-slide-container' v-show='isShow'>
    <slot name='section'></slot> 
  </div>
</div>

先初始化容器寬度

//所有data
data(){
  return{
    fullpage:{
      //當前處于第幾個div
      current:1,
      isScrolling: false,
      // 返回鼠標滾輪的垂直滾動量
      deltaY:0,
    },
    //顯示滾動盒子
    isShow:false,
    //是否允許滾動
    isAllowScroll:true,
    api:{
     setAllowScrolling:this.setAllowScrolling
    }
  }
},
mounted() {
  this.initFullPage()
  //窗口resize時候重新設計大小
  window.addEventListener('resize',this.resizeEventHandler)
},
beforeDestroy() {
  //組件銷毀的時候remove事件監(jiān)聽
  window.removeEventListener("resize", this.resizeEventHandler, false);
},
methods:{
  resizeEventHandler(){
    //節(jié)流,考慮效率
    throttle(this.initFullPage(),300)
  },
  initFullPage(){
    //初始化容器寬高度
    this.isShow=false
    let height = this.$refs['v-fullpage'].clientHeight;
    let width=this.$refs['v-fullpage'].clientWidth;
    //手動寫容器的寬度
    this.direction=='horizontal'?this.$refs['v-slide-container'].style.width=`${width*this.$slots.section.length}px`:null;
    //手動設置slots里面為section的樣式
    this.$slots.section.forEach((item)=>{
      item.elm.style.height=`${height}px`
      item.elm.style.width=`${width}px`
    })
    //顯示滾動盒子
    this.isShow=true
  },
}

滾輪事件

methods:{
  next() {
      let len = this.$slots.section.length;
      if((this.fullpage.current + 1) <= len) {
        this.fullpage.current += 1;
        this.move(this.fullpage.current);
      }
    },
    pre() {
      if(this.fullpage.current -1 > 0) {
        this.fullpage.current -= 1;
        this.move(this.fullpage.current);
      }
    },
    move(index) {
      // 為了防止?jié)L動多次滾動,需要通過一個變量來控制是否滾動
      this.fullpage.isScrolling = true;
      this.directToMove(index)
      this.$emit('leaveSlide',{currentIndex:this.fullpage.current})
      //這里的動畫是1s執(zhí)行完,使用setTimeout延遲1s后解鎖
      setTimeout(()=>{
        this.fullpage.isScrolling = false;
      }, 1010);
    },
    directToMove(index){
     let height = this.$refs['v-fullpage'].clientHeight;
     let width=this.$refs['v-fullpage'].clientWidth;
     let $scroll = this.$refs['v-slide-container'];
     //位移多少
     let displacement 
     //判斷是垂直滾動還是橫向滾動
     if(this.direction=='vertical'){
      displacement = -(index-1)*height + 'px';
      $scroll.style.transform=`translateY(${displacement})`
     }else{
      displacement = -(index-1)*width + 'px';
      $scroll.style.transform=`translateX(${displacement})`
     }
     this.fullpage.current = index
    },
    mouseWheelHandle (event) {
      if(!this.isAllowScroll){//是否可以滾動
       return
      }
      if (this.fullpage.isScrolling) {// 加鎖部分
        return false;
      }
      let e = event.originalEvent || event;
      this.fullpage.deltaY = e.deltaY;
      if (this.fullpage.deltaY > 0) {
        this.next();
      } else if (this.fullpage.deltaY < 0) {
        this.pre();
      }
    },
    setAllowScrolling(isAllow){
     this.isAllowScroll=isAllow
    },
}

寫到這里基本就完成了,我們需要打包成別人可以用的。感謝vue-cli3,都封裝的非常好了。

打包

在package.json的scripts增加一個命令,然后執(zhí)行npm run build:lib

"scripts": {
  "build:lib": "vue-cli-service build --target lib --name v-fullpage ./src/components/index.js",
 },

這樣我們就會打包到dist幾個文件,主要打包成了umd(瀏覽器可以引用)和commonjs模塊規(guī)范的包。
參考Vue Cli3 構建目標:庫

發(fā)布

pacakage.json發(fā)布到npm的字段

配置 package.json 文件中發(fā)布到 npm 的字段

name: 包名,該名字是唯一的。npm官網搜索一下有沒有,這里我們取v-fullpage
version: 版本號,每次發(fā)布至 npm 需要修改版本號
description: 描述。
main: 入口文件,import/require的
keyword:關鍵字,以空格分離希望用戶最終搜索的詞。
author:作者
private:是否私有,需要修改為 false 才能發(fā)布到 npm

npm官網注冊npm賬號,有就不需要

回到我們的目錄下,npm login

發(fā)布,npm publish

需要等一下,npm官網搜索

使用

import Vue from "vue";
import fullpage from "v-fullpage";

Vue.use(fullpage);

or

<script src="vue.min.js"></script>
<!-- must place this line after vue.js -->
<script src="v-fullpage.umd.min.js"></script>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Vue-cli 使用json server在本地模擬請求數據的示例代碼

    Vue-cli 使用json server在本地模擬請求數據的示例代碼

    本篇文章主要介紹了Vue-cli 使用json server在本地模擬請求數據的示例代碼,非常具有實用價值,需要的朋友可以參考下
    2017-11-11
  • vue-router路由懶加載及實現的3種方式

    vue-router路由懶加載及實現的3種方式

    這篇文章主要給大家介紹了關于vue-router路由懶加載及實現的3種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02
  • web開發(fā)中如何優(yōu)雅的解決"重復請求"問題

    web開發(fā)中如何優(yōu)雅的解決"重復請求"問題

    在我們的日常開發(fā)當中,很多時候會出現短時間內重復請求的情況,如果沒有妥當地處理后果很嚴重,這篇文章主要給大家介紹了關于web開發(fā)中如何優(yōu)雅的解決重復請求問題的相關資料,需要的朋友可以參考下
    2022-05-05
  • vue3深入學習?nextTick和historyApiFallback

    vue3深入學習?nextTick和historyApiFallback

    這篇文章主要介紹了vue3深入學習?nextTick和historyApiFallback,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-08-08
  • 簡單實現一個vue公式編輯器組件demo

    簡單實現一個vue公式編輯器組件demo

    這篇文章主要介紹了輕松實現一個簡單的vue公式編輯器組件示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2024-01-01
  • element-ui中el-cascader動態(tài)加載和默認值詳解

    element-ui中el-cascader動態(tài)加載和默認值詳解

    vue+elementUI項目中el-cascader級聯選擇器使用頻率非常高,下面這篇文章主要給大家介紹了關于element-ui中el-cascader動態(tài)加載和默認值的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-05-05
  • vue webpack實用技巧總結

    vue webpack實用技巧總結

    本篇文章給大家總結了vue+webpack的實用技巧以及相關實例代碼分享,有興趣的朋友可以參考學習下。
    2018-04-04
  • vue2中provide/inject的使用與響應式傳值詳解

    vue2中provide/inject的使用與響應式傳值詳解

    Vue中 Provide/Inject實現了跨組件的通信,下面這篇文章主要給大家介紹了關于vue2中provide/inject的使用與響應式傳值的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-09-09
  • vue實現3D切換滾動效果

    vue實現3D切換滾動效果

    這篇文章主要為大家詳細介紹了vue實現偽3D切換滾動效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 在vant 中使用cell組件 定義圖標該圖片和位置操作

    在vant 中使用cell組件 定義圖標該圖片和位置操作

    這篇文章主要介紹了在vant 中使用cell組件 定義圖標該圖片和位置操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11

最新評論