這篇文章主要為大家展示了“Vue2x如何實現(xiàn)響應(yīng)式自適應(yīng)輪播組件插件VueSliderShow功能”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Vue2x如何實現(xiàn)響應(yīng)式自適應(yīng)輪播組件插件VueSliderShow功能”這篇文章吧。
創(chuàng)新互聯(lián)公司不只是一家網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司;我們對營銷、技術(shù)、服務(wù)都有自己獨特見解,公司采取“創(chuàng)意+綜合+營銷”一體化的方式為您提供更專業(yè)的服務(wù)!我們經(jīng)歷的每一步也許不一定是最完美的,但每一步都有值得深思的意義。我們珍視每一份信任,關(guān)注我們的成都網(wǎng)站設(shè)計、做網(wǎng)站質(zhì)量和服務(wù)品質(zhì),在得到用戶滿意的同時,也能得到同行業(yè)的專業(yè)認(rèn)可,能夠為行業(yè)創(chuàng)新發(fā)展助力。未來將繼續(xù)專注于技術(shù)創(chuàng)新,服務(wù)升級,滿足企業(yè)一站式全網(wǎng)整合營銷推廣需求,讓再小的品牌網(wǎng)站設(shè)計也能產(chǎn)生價值!
VueSliderShow故名思意,vue的輪播圖組件插件,該插件:
1、支持瀏覽器任意放縮,兼容移動端,
2、支持自動切換,鼠標(biāo)經(jīng)過停止切換,分頁/任意頁點擊切換,左右切換,
3、支持文字介紹(超過一行自動省略)
本文講述的是從開發(fā)一款基于Vue2x的響應(yīng)式自適應(yīng)輪播組件插件的一個全過程,包含發(fā)布到npm,構(gòu)建自己的npm包,供下載安裝使用的技巧,閱讀本文需要些Vue的語法糖(自定義標(biāo)簽、計算屬性、父子組件通信等),以及ES6、npm等基礎(chǔ)知識。先來看下Demo
示例源碼地址
Install
npm i vueslideshow
使用示例
in vue2.x:
<template> //輪播組件的位置 <div> <slider-show :slides="slides" :inv="invTime"></slider-show> </div> </template> <script> import sliderShow from 'vueslidershow' export default { components: { sliderShow }, data () { return { invTime: 2000, slides: [ { src: require('../assets/1.jpg'), title: '測試測試測試1', href: 'detail/analysis' } ] } } }
參數(shù)說明:
1.invTime:控制輪播速度
2.slides:具體的輪播數(shù)據(jù)數(shù)組形式,包含圖片,文字,鏈接三個參數(shù)
3.注意:由于是響應(yīng)式自適應(yīng)所以推的圖片必須高度一致
分割線,下面開始上路,步入主題!!
寫在前面:vue官網(wǎng)提供了開發(fā)插件的介紹,感興趣的老鐵可以先移步官網(wǎng)開發(fā)插件,
創(chuàng)建項目
0、想必各位老鐵都是有vue和前端經(jīng)驗的了,這些基礎(chǔ)項目環(huán)境和搭建項目,改造初始化的vue項目都是睜眼閉眼的事情了,所以這里都一筆帶過:
1、vue環(huán)境配備,(node、vue-cli)
2、初始化項目,Vue init webpack vueslideshow。安裝依賴npm install(安裝的時候把vue-router默認(rèn)一起安裝上去)
改造初始化項目:
(0)改造前分析一下我們的需求:一個響應(yīng)式自適應(yīng)輪播組件,之所以是組件,是我們希望可以公用的代碼段,支持可動態(tài)配置,輪播組件無非就說圖片文字,自動切換,可選擇切換。
(1)app.vue里清空到如下就好
<template> <div id="app"> <router-view/> </div> </template> <script> export default { name: 'App' } </script>
(2)在components文件夾里,創(chuàng)建index.vue,sliderShow.vue(因為是示例項目,規(guī)范上欠佳)讓router文件夾里的index.js啟動頁指向index.vue
import Vue from 'vue' import Router from 'vue-router' import Index from '@/components/index' Vue.use(Router) export default new Router({ routes: [ { path: '/', component: Index } ] })
開發(fā)項目:
(1)index.vue作為父組件,通過es6的方式引用輪播組件,聲明使用輪播sliderShow組件,然后給sliderShow組件傳遞兩個 invTime、slides屬性參數(shù),分別是輪播切換時間和數(shù)據(jù)傳遞,我們這里slides數(shù)組,用的是靜態(tài)模擬數(shù)據(jù),正式環(huán)境是通過請求接口請求的數(shù)據(jù)。
<template> <div> <slider-show :slides="slides" :inv="invTime"></slider-show> </div> </template> <script> import sliderShow from './sliderShow' export default { components: { sliderShow }, data () { return { invTime: 2000, slides: [ { src: require('../assets/1.jpg'), title: '測試測試測試1', href: 'detail/analysis' }, { src: require('../assets/2.jpg'), title: '測試測試測試2', href: 'detail/count' } ] } } }
(2)sliderShow.vue
模板段代碼讀解(布局這里就略講了),最外層分別有兩個鼠標(biāo)經(jīng)過clearInv事件,主要是希望在鼠標(biāo)經(jīng)過焦點圖的時候不進行切換方便點圖片跳轉(zhuǎn),鼠標(biāo)移出執(zhí)行runInv事件繼續(xù)自動切換,transition分別去控制兩張圖的出現(xiàn)和消失,左右切換,和點擊具體的分頁切換這里用通用的一個goto()方法轉(zhuǎn)遞不同值,去判斷具體要展示的數(shù)據(jù)頁,這個值的計算可以通過vue里的計算屬性。
<template> <div class="slide-show" @mouseover="clearInv" @mouseout="runInv"> <div class="slide-img"> <a :href="slides[nowIndex].href" rel="external nofollow" > <transition name="slide-fade"> <img v-if="isShow" :src="slides[nowIndex].src"> </transition> <transition name="slide-fade-old"> <img v-if="isShows" :src="slides[nowIndex].src"> </transition> </a> </div> <div class="slide-title"><a>{{ slides[nowIndex].title }}</a></div> <ul class="slide-pages"> <li v-for="(item, index) in slides" @click="goto(index)" > <a :class="{on: index === nowIndex}"></a> </li> </ul> <a @click="goto(prevIndex)" class="callbacks-nav"><</a> <a @click="goto(nextIndex)" class="callbacks-nav next">></a> </div> </template> <script> export default { props: { slides: { type: Array, default: [] }, inv: { type: Number, default: 1000 } }, data () { return { nowIndex: 0, isShow: true, isShows:false } }, computed: { prevIndex () { if (this.nowIndex === 0) { return this.slides.length - 1 } else { return this.nowIndex - 1 } }, nextIndex () { if (this.nowIndex === this.slides.length - 1) { return 0 } else { return this.nowIndex + 1 } } }, methods: { goto (index) { this.isShow = false setTimeout(() => { this.nowIndex = index this.isShows = true }, 10) }, runInv () { this.invId = setInterval(() => { this.goto(this.nextIndex) }, this.inv) }, clearInv () { clearInterval(this.invId) } }, mounted () { this.runInv(); } } </script>
ES6邏輯段代碼解讀,sliderShow.vue通過props方式接受父組件里傳遞過來的數(shù)據(jù)
props: { slides: { type: Array, default: [] }, inv: { type: Number, default: 1000 } },
計算屬性,前一頁,這里就控制nowIndex,在當(dāng)前數(shù)據(jù)索引里減一,當(dāng)是第一條數(shù)據(jù)的時候,我們要跳到最后一條,所以當(dāng)?shù)谝粭l數(shù)據(jù)的時候我們這里判斷它并讓他賦值最后一條數(shù)據(jù),后一頁和前一頁相似,判斷最后一頁數(shù)據(jù),跳到第一頁。
computed: { prevIndex () { if (this.nowIndex === 0) { return this.slides.length - 1 } else { return this.nowIndex - 1 } }, nextIndex () { if (this.nowIndex === this.slides.length - 1) { return 0 } else { return this.nowIndex + 1 } } },
通過Index值,從而改變具體數(shù)據(jù)
goto (index) { this.isShow = false setTimeout(() => { this.nowIndex = index this.isShows = true }, 10) },
當(dāng)頁面加載完后直接執(zhí)行runInv()方法,然后自動切換,setInterval()/ clearInterval()是js內(nèi)置的定時器,setInterval()里按照父組件里傳的時間來調(diào)用函數(shù)的方法,clearInterval()是結(jié)束定時器的循環(huán)調(diào)用函數(shù)
runInv () { this.invId = setInterval(() => { this.goto(this.nextIndex) }, this.inv) }, clearInv () { clearInterval(this.invId) } }, mounted () { this.runInv(); }
輪播組件插件就基本上ok了,下面講解一下把這個輪播組件插件放到npm里,構(gòu)建自己的npm包。
分割線 npm?。。。。?/p>
構(gòu)建npm包:
0、在https://www.npmjs.com創(chuàng)建自己的賬號
1、新建一個項目文件夾VueSliderShow,把上面的sliderShow.vue文件復(fù)制文件。打開cmd進入到VueSliderShow目錄,然后命令行執(zhí)行:npm init(按流程填寫相關(guān)信息,都可以按照自己的實際情況寫),然后會生成一個package.json,例如下面是我這個組件的基本信息
{ "name": "vueslideshow", "version": "1.0.2", "description": "a slider implement by vuejs", "main": "index.js", "scripts": { "test": "echo \"Error: no test specified\" && exit 1" }, "repository": { "type": "git", "url": "https://github.com/HongqingCao/My-Code/tree/master/VueSliderShow" }, "author": "HongqingCao", "license": "ISC" }
2、創(chuàng)建一個index.js
var sliderShow = require('./sliderShow') module.exports = sliderShow
3、創(chuàng)建一個README.md,描述一下這個組件,可以參考一下我寫的
# vueslidershow > a slider implement by vuejs >一個vue的響應(yīng)式自適應(yīng)輪播圖組件 [Demo](https://github.com/HongqingCao/My-Code/tree/master/VueSliderShow) ###### ![實例效果](https://github.com/HongqingCao/My-Code/blob/master/VueSliderShow/VueSlider.gif) ## Install ``` bash npm i vueslideshow ``` ## 應(yīng)用案例 #### in vue2.x: ```html <template> <div> <slider-show :slides="slides" :inv="invTime"></slider-show> </div> </template> <script> import sliderShow from './sliderShow' export default { components: { sliderShow }, data () { return { invTime: 2000, slides: [ { src: require('../assets/1.jpg'), title: '測試測試測試1', href: 'detail/analysis' } ] } } } ``` <br> ### 參數(shù)說明: 1.invTime,控制輪播速度 2.slides,具體的輪播數(shù)據(jù)數(shù)組形式,包含圖片,文字,鏈接三個參數(shù) 3.由于是響應(yīng)式自適應(yīng)所以推的圖片必須高度一致,更友好 ## License [MIT](LICENSE)
4、命令行npm login,登錄自己的賬號和密碼
5、發(fā)布到npm執(zhí)行命令行: npm publish
,成功后你會發(fā)現(xiàn)你的npm里已經(jīng)有一個包了
你可以點擊進入詳情看看
6、嘗試下載安裝在自己項目里:npm i vueslideshow
,安裝完后在node_modules就可以看到自己的插件啦
7、應(yīng)用就如一開始的插件介紹一樣,可以往上看
以上是“Vue2x如何實現(xiàn)響應(yīng)式自適應(yīng)輪播組件插件VueSliderShow功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
分享題目:Vue2x如何實現(xiàn)響應(yīng)式自適應(yīng)輪播組件插件VueSliderShow功能
文章地址:http://muchs.cn/article44/jsohhe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、App開發(fā)、面包屑導(dǎo)航、網(wǎng)站維護、定制網(wǎng)站、網(wǎng)站導(dǎo)航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)