日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

vue3.0封裝輪播圖組件的步驟

瀏覽:19日期:2022-10-03 18:06:38

接著上一篇文章,熟悉vue3.0的基本用法,和使用一段時間以后,開始準(zhǔn)備開發(fā)適用于vue3.0使用的pc端的組件庫。會陸續(xù)跟新一些組件庫的寫法和注意事項,有興趣的同學(xué)可以多多關(guān)注哦,不多bb,開始。

開發(fā)一個輪播圖組件,適用pc端,(暫無考慮app), 使用于vue3.0 + TS

大致的實現(xiàn)效果是這樣:

vue3.0封裝輪播圖組件的步驟

圖片自由輪播,對應(yīng)圓點圖片跳轉(zhuǎn),左右指示器跳轉(zhuǎn)等。暴露以下options配置:

vue3.0封裝輪播圖組件的步驟

以上是主要的options,下面展開來說一下具體如何封裝。

一:封裝思想

在vue3.0和vue2.0中封裝組件其實核心思想都是一樣的,需要使用到vue.component();對組件進行注冊,之后在main.ts中掛載一下就可以使用。

在 src下面創(chuàng)建: src --> libs --> sqm_ui(自己UI庫的名稱)-->index.js

這里的index.js就是注冊組件的入口。

同級目錄下新建一個文件, Carousel, 這個文件包含所有的輪播組件的功能和樣式。

目錄如下:

vue3.0封裝輪播圖組件的步驟

要注意一點: 雖然是在vue3.0和ts中使用,但是入口文件還是用js,這也是為了可以適用非ts寫法。

在index.js中:

import Carousel from ’./Carousel/carousel’;import CarItem from ’./Carousel/item’;let SqmUI = {};SqmUI.install = function(vue) { vue.component(Carousel.name, Carousel); vue.component(CarItem.name,CarItem);};export default SqmUI;

但是為了配合TS使用,我們需要新建一個index.d.ts文件,用來描述庫中成員類型來給TS用。

declare const _default: ({ install: (app: import('vue').App<any>, ...options: any[]) => any; // 這里單純描述一下install});export default _default;

完成以上配置后,在main.ts中使用:

import SqmUI from ’@/libs/sqm_ui/index’;import { createApp } from ’vue’;createApp.use(SqmUI);二:封裝流程

對于輪播圖而言,我們需要一個固定的容器,來放置每一張滾動的圖片,這時候我們需要定義一個Carousel.vue組件。

<template> <div class='carousel'> <slot></slot> // 這里的slot是用來放置item組件 </div></template>

還需要一個用來存儲照片的組件,item.vue

<template> <div class='carousel-item'> <slot></slot> // 這里的slot是用來放置img </div></template>

基本框架搭好,當(dāng)用戶使用的時候在carousel中配置options。

<carousel :autoPlay='true' :durdation='3000' :initial='3' :hasDot='true' :hasDirector='true'> </carousel>

在carousel.vue中:接受傳來的配置項

props: { autoplay: { type: Boolean, default: true }, duration: { type: Number, default: 3000 }, initial: { type: Number, default: 0 }, hasDot: { type: Boolean, default: true }, hasDirector: { type: Boolean, default: true }}

(1): 實現(xiàn)autoPlay:

在carousel.vue中:

const autoPlay = () => { if (props.autoplay) { t = setInterval(() => { // 輪播邏輯 }, props.duration);};onMounted(() => { autoPlay();});

邏輯很簡單,定義一個autoPlay函數(shù),在mounted階段掛載。

(2): 實現(xiàn)輪播:

想這樣一個問題:如何才能讓這一張圖片顯示?一定需要當(dāng)前圖片的index,等于輪播時的index才可以顯示。

在item.vue中:

<div v-if='selfIndex === currentIndex'> <slot></slot> </div>

只有當(dāng)自身的index,等于當(dāng)前的index的時候才能顯示。

獲取currentIndex:

vue3.0中內(nèi)置方法: getCurrentInstance()

這是一個很重要的方法,通過這個方法我們可以獲取當(dāng)前組件的實例,然后通過ctx獲取該組件的上下文。特別好用。

在item.vue中:

setup() { const instance:any = getCurrentInstance(); console.log(instance);}

vue3.0封裝輪播圖組件的步驟

在instance.vnode下面有個key是每個圖片對應(yīng)的自身的key也就是index。

在instance.parent.ctx 下面有個定義的currentIndex,是當(dāng)前的index。

當(dāng)二者相同時,可以顯示當(dāng)前圖片。那么currentIndex在哪里設(shè)置呢?

回到carousel.vue中:

setup(props) { const state = reactive({ currentIndex: props.initial, itemLen: 0, showDir: false });}

當(dāng)前的currentIndex就是傳入的initial的值。

在autoPlay中:執(zhí)行輪播

const setIndex = ((dir:String): void => { switch(dir) { case ’next’: state.currentIndex += 1; if (state.currentIndex === state.itemLen) { state.currentIndex = 0; } break; case ’prev’: state.currentIndex -= 1; if (state.currentIndex === -1) { state.currentIndex = state.itemLen - 1; } break; default: break; } });

當(dāng)next的時候,讓currentIndex++; 直到等于輪播圖片的長度。(array.length)

當(dāng)prev的時候, 讓currentIndex--; 直到=== -1

之后在item.vue中監(jiān)聽一下:

watch(() => { return instance.parent.ctx.currentIndex }, (value) => { state.currentIndex = value; })

這樣就完成圖片的輪播。

三: 圓點指示器

實現(xiàn)的思想還是很簡單的:

通過傳入的hasDot來確定需不需要顯示。傳入itemLen根據(jù)圖片的數(shù)量來確定顯示幾個圓點,點擊圓點可以跳轉(zhuǎn)到對應(yīng)的圖片上。

在dot.vue中:

<template> <div v-if='hasDot'> <div v-for='item in itemLen' :key='item'> <a href='javascript:;' rel='external nofollow' rel='external nofollow' rel='external nofollow' : @click='dotClick(item - 1)'> </a> </div> </div></template><script lang='ts'>import {defineComponent} from ’vue’;export default defineComponent({ name: ’dot’, props: { itemLen: Number, currentIndex: Number, dotBgColor: { type: String, default: ’#ff5000’ }, hasDot: { type: Boolean, default: true } }, setup(props, ctx) { const dotClick = (index: Number) => { ctx.emit(’dotClick’, index); }; return { dotClick } }})</script>

通過ctx觸發(fā)dotClick事件,把index傳入,在父組件中使用(Carousel.vue):

@dotClick='dotClick'const dotClick = (index: any): void => {state.currentIndex = index;};

這樣完成了圓點指示器。

四: 左右指示器

這個很簡單,就是移入的時候顯示,然后點擊圖片滑動。

<template> <div v-if='showDir'> <div v-if='dir === ’next’'> <a href='javascript:;' rel='external nofollow' rel='external nofollow' rel='external nofollow' @click='dirClick(dir)'>&gt;</a> </div> <div v-else-if='dir === ’prev’'> <a href='javascript:;' rel='external nofollow' rel='external nofollow' rel='external nofollow' @click='dirClick(dir)'>&lt;</a> </div> </div></template><script lang='ts'>import {defineComponent} from ’vue’;export default defineComponent({ name: ’direct’, props: { dir: String, showDir: { type: Boolean, default: false } }, setup(props, ctx) { const dirClick = (dir: String) => { ctx.emit(’dirClick’, dir); }; return { dirClick } }})</script>

一樣的傳給父組件一個dirClick事件,在父組件中執(zhí)行點擊移動就可以了。

五:最后:

因為輪播圖是通過定時器實現(xiàn)的需要銷毀定時器。

onBeforeUnmount(() => { _clearFunction();});function _clearFunction(): void { clearInterval(t); t= null;};

在鼠標(biāo)移入時停止自動播放,顯示左右指示器:

const mouseEnter = (): void => { _clearFunction(); state.showDir = true; };

在鼠標(biāo)移出時開始播放, 左右指示器消失

const mouseLeave = (): void => { autoPlay(); state.showDir = false; };

ok. 大體的思想就是這樣,還有一些細(xì)節(jié)可以自己再多想想。感謝!!

六:往期回顧

www.jb51.net/article/206833.htm

以上就是vue3.0封裝輪播圖組件的步驟的詳細(xì)內(nèi)容,更多關(guān)于vue3.0封裝輪播圖組件的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
99视频一区| 亚洲女同av| 亚洲综合不卡| 中文一区在线| 久久亚洲欧美| 日本伊人久久| 亚洲免费毛片| 欧美一区91| 日韩精品一区二区三区中文 | 丝袜脚交一区二区| 首页国产欧美日韩丝袜| 一区二区三区四区日韩| 日韩综合一区二区| 国产麻豆精品久久| 欧美一级鲁丝片| 欧美日韩视频| 日本在线不卡视频| 精品久久中文| 亚洲伦乱视频| 激情91久久| 亚洲精品欧洲| 免费在线日韩av| 亚洲成人不卡| 日韩在线观看一区二区| 97久久超碰| 97国产成人高清在线观看| 99久久婷婷这里只有精品| 老司机精品久久| 国产欧美一区二区三区国产幕精品 | 欧美jjzz| 久久aⅴ国产紧身牛仔裤| 欧美日韩视频免费看| 精品中文在线| 1024精品久久久久久久久| 婷婷成人av| 国产不卡精品| 老牛国产精品一区的观看方式| 国产日韩一区二区三区在线| 日韩电影免费在线观看| 蜜臀精品久久久久久蜜臀 | 亚洲小说欧美另类婷婷| 综合一区二区三区| 欧美1区二区| 美女网站一区| 国产欧美日韩亚洲一区二区三区| 黑森林国产精品av| 免费在线欧美视频| 国产精品777777在线播放| 色88888久久久久久影院| 在线一区二区三区视频| 色乱码一区二区三区网站| 亚洲综合不卡| 久久伊人久久| 国产视频久久| 精品国产亚洲一区二区三区在线| 亚洲主播在线| 97精品国产| 日韩国产精品久久久久久亚洲| 在线天堂资源www在线污| 亚洲三级av| а√天堂中文在线资源8| 婷婷综合一区| 欧美综合另类| 欧美激情在线精品一区二区三区| 婷婷成人基地| 精品视频黄色| 日韩国产欧美三级| 国模 一区 二区 三区| 国产精品一区二区精品| 日韩午夜精品| 色婷婷色综合| 国产日韩欧美三区| 亚洲免费激情| 日韩理论视频| 国产精选久久| 亚洲精品伊人| 宅男在线一区| 日本不卡免费高清视频在线| 久久国内精品自在自线400部| 精品一区免费| 蜜臀国产一区| 欧美成人精品午夜一区二区| 视频一区二区三区入口| 久久久久.com| 韩国久久久久久| 欧美激情久久久久久久久久久| 亚洲aa在线| 久久av一区| 伊人久久亚洲热| 91精品蜜臀一区二区三区在线| 久久久久亚洲精品中文字幕| 欧美在线看片| 中文字幕一区二区av| 不卡av一区二区| 91精品国产自产在线观看永久∴| 福利一区在线| 精品国产亚洲一区二区三区在线| 日本不卡一二三区黄网| 午夜一区在线| 国产精品毛片在线看| 四虎影视精品| 91看片一区| 国产 日韩 欧美一区| 91偷拍一区二区三区精品| 精品中文字幕一区二区三区四区| 国产精品视频3p| 国产精品手机在线播放| 91av一区| 国产日产精品一区二区三区四区的观看方式| 午夜欧美精品久久久久久久| 久久蜜桃精品| 国产91一区| 亚洲一本视频| 久久久久99| 亚洲国产综合在线看不卡| 久久精品不卡| 999久久久91| 欧洲毛片在线视频免费观看| 婷婷中文字幕一区| 影院欧美亚洲| 男女性色大片免费观看一区二区| 久久午夜精品一区二区| 视频一区中文字幕| 亚洲精品成a人ⅴ香蕉片| 亚洲精品乱码| 久久精品72免费观看| 国产欧美午夜| 久久精品国产999大香线蕉| 久久超碰99| 激情丁香综合| 免播放器亚洲| 亚洲18在线| 国产精品一线天粉嫩av| 国产精品伊人| 国产a亚洲精品| 久久久国产亚洲精品| 欧美日韩免费观看一区=区三区| 亚洲一区二区毛片| 日韩亚洲精品在线观看| 国产乱码精品一区二区三区四区 | 美日韩精品视频| 综合欧美亚洲| 国产精品一页| 日韩电影免费网站| 9色精品在线| 欧美日韩91| 四虎国产精品免费观看| 婷婷成人综合| 一区二区电影| 久久婷婷国产| 成人午夜精品| 视频在线观看一区| 国产精品久久免费视频| 亚洲涩涩在线| 水野朝阳av一区二区三区| 久久精品av麻豆的观看方式| 国产一区二区三区黄网站| 免费不卡中文字幕在线| 日韩午夜视频在线| 超碰在线99| 另类av一区二区| 美女精品一区二区| 欧美午夜不卡| 国产情侣久久| 1000部精品久久久久久久久| 最新国产精品| 另类综合日韩欧美亚洲| 影视先锋久久| 欧美日韩va| 999精品一区| 国产无遮挡裸体免费久久| 欧美sm一区| 日本在线不卡视频| 日韩欧美精品综合| 日韩中出av| 天堂日韩电影| 91p九色成人| 亚洲91视频| 国产美女亚洲精品7777| 亚洲欧美伊人| 国产日韩欧美中文在线| 国产99久久| 国产黄色一区| 老司机久久99久久精品播放免费| 久久精品国产网站| 午夜亚洲福利在线老司机| 欧美国产精品| 自拍自偷一区二区三区| 亚洲精品国产嫩草在线观看| 婷婷亚洲成人| 精品日韩毛片| 国产一区二区三区网| 中文字幕中文字幕精品| 国产精品亚洲一区二区三区在线观看| 日韩一区二区三区精品| 欧洲精品一区二区三区| 欧美日本一区| 国产模特精品视频久久久久| 黄毛片在线观看| 国产精品午夜av|