亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

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

2019-11-19 12:01:11
字體:
來源:轉載
供稿:網友

前言

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

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

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

GITHUB

鏈接

開始

準備

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

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

思考

一開始要想別人如何調用我們寫的組件,通過掛載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,禁止滾動/開放滾動事件

目錄結構

├─ 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'>//監聽鼠標滾輪事件  <div class="v-slide-container" :class="direction" ref='v-slide-container' v-show='isShow'>    <slot name='section'></slot>   </div></div>

先初始化容器寬度

//所有datadata(){  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事件監聽  window.removeEventListener("resize", this.resizeEventHandler, false);},methods:{  resizeEventHandler(){    //節流,考慮效率    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) {      // 為了防止滾動多次滾動,需要通過一個變量來控制是否滾動      this.fullpage.isScrolling = true;      this.directToMove(index)      this.$emit('leaveSlide',{currentIndex:this.fullpage.current})      //這里的動畫是1s執行完,使用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增加一個命令,然后執行npm run build:lib

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

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

發布

pacakage.json發布到npm的字段

配置 package.json 文件中發布到 npm 的字段

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

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

回到我們的目錄下,npm login

發布,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>

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美亚洲激情视频| 成人国产亚洲精品a区天堂华泰| 日韩少妇与小伙激情| 亚洲自拍偷拍色片视频| 国产手机视频精品| 久久频这里精品99香蕉| 欧美最猛性xxxxx免费| 国内揄拍国内精品少妇国语| 亚洲欧美日韩一区二区在线| 日韩欧美精品中文字幕| 91精品国产自产在线| 国产精品一区久久久| 国产精品久久久久久久久久久久| 欧美电影在线观看网站| 色www亚洲国产张柏芝| 亚洲精品久久久久久久久久久久久| 麻豆精品精华液| 国产成人精品日本亚洲专区61| 久久视频免费在线播放| 91丨九色丨国产在线| 成人h片在线播放免费网站| 亚洲丝袜在线视频| 日韩精品在线免费观看| 国产aⅴ夜夜欢一区二区三区| 午夜精品www| 欧美一级视频在线观看| 国产精品一二三视频| 欧美精品一区在线播放| 久久久国产精品x99av| 欧美日韩国产精品一区二区不卡中文| 亚洲色图13p| 亚洲精品v欧美精品v日韩精品| 中文国产成人精品| 亚洲国模精品一区| 91精品综合视频| 亚洲精品视频网上网址在线观看| 欧美午夜精品在线| 精品国产成人av| 亚洲美女在线视频| 中文字幕欧美视频在线| 国产日本欧美一区二区三区在线| 亚洲视频视频在线| 亚洲国产成人精品久久| 欧美日韩成人在线视频| 亚洲精品白浆高清久久久久久| 91色p视频在线| 欧美国产日韩一区二区| 精品爽片免费看久久| 亚洲精品一区二三区不卡| 国内精品久久久久久| 欧美有码在线观看| 国产视频欧美视频| 午夜精品久久久久久久99热浪潮| 久久av红桃一区二区小说| 亚洲新中文字幕| 欧美麻豆久久久久久中文| 久久人人爽人人爽人人片av高请| 国产成人精品免高潮在线观看| 亚洲视频在线视频| 亚洲天堂av女优| 5252色成人免费视频| 国产精品久久久久久久久久久新郎| 久久久国产精品x99av| 亚洲最大av网站| 亚洲无限av看| 欧美亚洲另类视频| 久久久久久久色| 色伦专区97中文字幕| 亚洲欧美在线免费| 日本一区二区三区在线播放| 国产一区二区三区丝袜| 国产精品高潮呻吟久久av黑人| 久久中文字幕在线视频| 伦理中文字幕亚洲| 久久久国产精彩视频美女艺术照福利| 久久999免费视频| 亚洲国内精品视频| 国产一区二区三区网站| 欧美男插女视频| 136fldh精品导航福利| 91精品久久久久久综合乱菊| 欧美国产日韩一区二区三区| 日韩成人av在线| 欧美夜福利tv在线| 国产精品久久久久久久久免费看| 亚洲男人天堂手机在线| 日韩av电影手机在线观看| 欧美噜噜久久久xxx| 亚洲曰本av电影| 91极品女神在线| 成人免费淫片视频软件| 在线亚洲男人天堂| 日本亚洲欧洲色α| 91综合免费在线| 日韩欧美在线免费| 欧美福利视频网站| 亚洲精品理论电影| 91国语精品自产拍在线观看性色| 欧洲亚洲女同hd| 亚洲精品国偷自产在线99热| 亚洲成**性毛茸茸| 91国产美女在线观看| 久久久成人精品视频| 中文字幕亚洲一区| 久久影视三级福利片| 欧洲亚洲在线视频| 久久亚洲精品一区| 在线免费观看羞羞视频一区二区| 国产精品丝袜高跟| 亚洲精品电影在线| 国产伦精品免费视频| 色伦专区97中文字幕| 欧美精品激情在线| 日韩视频―中文字幕| 亚洲毛片在线观看| 欧美精品制服第一页| 午夜精品蜜臀一区二区三区免费| 97在线看免费观看视频在线观看| 日韩av手机在线观看| 中文字幕无线精品亚洲乱码一区| 一区二区三区视频免费| 欧美黄色三级网站| 亚洲天天在线日亚洲洲精| 中日韩午夜理伦电影免费| 国产精品国模在线| 欧美激情视频网址| 久久影视免费观看| 久久理论片午夜琪琪电影网| 亚洲欧洲在线免费| 日韩中文字幕在线视频播放| 欧美大片大片在线播放| 日本精品va在线观看| 91国语精品自产拍在线观看性色| 欧美日韩在线视频一区| 欧美日韩在线视频一区| 国产+成+人+亚洲欧洲| 黑人巨大精品欧美一区二区免费| 欧美激情视频给我| 狠狠躁18三区二区一区| 欧美老女人性视频| 国产精品视频中文字幕91| 欧美高清视频一区二区| 国产精品精品视频一区二区三区| 日韩av在线电影网| 91影视免费在线观看| 97香蕉久久超级碰碰高清版| 自拍偷拍亚洲区| 国产亚洲激情视频在线| 97在线观看视频国产| 国产视频亚洲视频| 亚洲一区制服诱惑| 国产精品久久久久久久久久| 久久五月天综合| 国产欧美一区二区三区视频| 综合激情国产一区| 亚洲激情电影中文字幕| 亚洲成人国产精品| 韩国视频理论视频久久| 亚洲三级av在线| 免费不卡欧美自拍视频| 国产精品美女999| 国产精品扒开腿做爽爽爽的视频| 欧美最猛性xxxxx(亚洲精品)| 久久亚洲国产成人|