电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Vue + ts實現輪播插件的示例

瀏覽:2日期:2022-11-02 13:18:04

背景

最近在學習 ts,打算用 ts 寫一個練手項目,參照的網站內容是 wanandroid,這個接觸過android開發的同學可能更i了解一些,其實一開始是打算后臺全部都自己寫的,不過奈何一個懶字,所以現在的打算就是自己實現登錄注冊簡單的邏輯。這些都不重要,一開始實現輪播是打算在 vue 中引入輪播圖 swiper.js,后來想想還是自己寫算了。也當作熟悉 ts。先上效果圖(這里沒有動態圖片,各位同學可以自己實現)

代碼已經上傳 git,進度比較慢,如果可以各位大佬點個 star。 github.com/jiwenjie/vu…

Vue + ts實現輪播插件的示例

<!-- vue 實現輪播圖 --><template> <div : @mouseover='suspend' @mouseout='autoPlay' @blur='suspend' @focus='autoPlay'> <!-- 淡入淡出效果 --> <transition-group tag='ul' :name='animation'> <li v-for='(item, index) in bannerList' :key='item.id' v-show='curIndex === index'> <img :src='http://www.hdgsjgj.cn/bcjs/item[nameField]'> </li> </transition-group> <!-- 操作按鈕部分(底部導航器) --> <ul v-if='showPagination'> <li : v-for='(item, index) in bannerList' :key='item.id' @click='jump(item, index)'></li> </ul> <!-- 左側右側切換按鈕 --> <template v-if='showBtn'> <div class='common-btn-space pre-btn-space'> <span class='common-btn-span pre-btn-span'></span> </div> <div class='common-btn-space next-btn-space'> <span class='common-btn-span next-btn-span'></span> </div> </template> </div></template><!-- ts 文件拆分 --><script lang='ts'> // 兩種動畫背景 import { Component, Prop, Vue } from ’vue-property-decorator’ import swiper from ’./ts/swiper’ @Component({ name: ’Swiper’, mixins: [swiper], }) export default class extends Vue {}</script><!-- 樣式文件拆分 --><style lang='scss' scoped> @import url('./css/swiper.scss');</style>

ts文件

import { Component, Prop, Vue} from ’vue-property-decorator’import { Banner } from ’@/beans/index’ // 首頁banner圖@Component({ name: ’Swiper’, components: {},})export default class IndexPage extends Vue { @Prop({ default: 6000 }) private timeout: number; // 默認的切換banner圖的時長 @Prop({ default: 400 }) private height: number | string; // banner區域高度 @Prop({ default: () => [] }) private bannerList: Banner[]; // 傳入的圖片數組 @Prop({ default: ’imagePath’ }) private nameField: string; // 圖片地址對應的字段名 @Prop({ default: true }) private showPagination: boolean; // 是否顯示底部原點分頁器 @Prop({ default: false }) private showBtn: boolean; // 是否顯示左右的切換按鈕 @Prop({ default: ’fade’, validator: function (value) { let arr = [’fade’, ’translate’] return arr.includes(value); } }) private animation: string; // 是否顯示左右的切換按鈕 private timer: any; private curIndex: number = 0; created(): void { this.autoPlay() } // lifecycle hook mounted(): void { } // method private handleSelect() { } // 自動播放圖片 private autoPlay() { clearInterval(this.timer)//還是一樣,開啟定時器之前需要先清除一下,防止bug this.timer = setInterval(this.nextClick, this.timeout as number) } // 切換下一個 banner 圖片 private nextClick() { this.curIndex++; if (this.curIndex >= this.bannerList.length) { this.curIndex = 0; } } // 切換上一個圖片 private preClick() { this.curIndex++; if (this.curIndex >= this.bannerList.length) { this.curIndex = 0; } } // 暫停的方法 private suspend() { clearInterval(this.timer) } // 點擊底部原點按鈕調整方法 private jump(bannerItem: Banner, index: number) { this.curIndex = index; } // private animationMethodValidator(): string { // }}

css文件

#swiperDIV { position: relative; display: block; width: 100%;}.img-list { width: 100%; height: 100%; position: relative; margin: 0; padding: 0; z-index: 9;}.img-list li { position: absolute; left: 0; width: 100%; height: 100%;}.img-list img { width: 100%; height: 100%;}.option-list { position: absolute; left: 0; right: 0; bottom: 10px; height: 30px; line-height: 30px; z-index: 99; text-align: center;}.option-list-item { display: inline-block; background-color: rgba(255, 255, 255, .4); width: 10px; height: 10px; border-radius: 50%; margin: 0 3px; cursor: pointer;}.cur-option-style { background-color: #fff;}.common-btn-space { position: absolute; top: 0; bottom: 0; z-index: 99; width: 22px;}.pre-btn-space { left: 20px;}.next-btn-space { right: 20px;}.common-btn-span { display: inline-block; width: 22px; height: 22px; background-color: transparent; cursor: pointer; position: absolute; top: 0; bottom: 0; margin: auto; border-top: 2px solid transparent; border-right: 2px solid transparent; border-bottom: 2px solid red; border-left: 2px solid red;}.pre-btn-span { transform: rotate(45deg);}.next-btn-span { transform: rotate(-135deg);}/* 實現動畫的兩組類(淡入淡出) */.fade-enter-active,.fade-leave-active { transition: opacity .6s;}.fade-enter,.fade-leave-to { opacity: 0;}/* (滾動) */.translate-enter { transform: translateX(100%)}.translate-enter-to { transition: all .6s ease; transform: translateX(0);}.translate-leave { transform: translateX(0)}.translate-leave-active { transition: all .6s ease; transform: translateX(-100%)}

很多地方做了配置,包括底部的分頁器,左右兩側的按鈕。動畫目前只實現了兩種,一種是淡入淡出,一種是平滑滾動。

這里我把整個 vue 文件做了拆分。有多種原因,一個是我司做項目時整體就是這種拆分,不過我司用的就是正常的 vue 和 js。主要原因就是考慮到頁面復雜和邏輯交互很多的時候,一個 vue 文件可能超過萬行,所以做了拆分,這里我也延續了這種寫法,基本思想其實就是使用 mixins 引入 ts。還有一個原因是 ts 在 vue 文件中會有很多莫名其妙的報錯,明明代碼沒問題,但就是有錯誤警告。如果提到 ts 文件中就正常,這也是我拆分的一個原因。

其他的功能可以自己在加,如果有問題可以留言,有錯誤希望各位大佬指正。

以上就是Vue + ts實現輪播插件的示例的詳細內容,更多關于Vue + ts 輪播插件的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
主站蜘蛛池模板: 北京律师咨询_知名专业北京律师事务所_免费法律咨询 | 精密钢管,冷拔精密无缝钢管,精密钢管厂,精密钢管制造厂家,精密钢管生产厂家,山东精密钢管厂家 | 蜂窝块状沸石分子筛-吸附脱硫分子筛-萍乡市捷龙环保科技有限公司 | 烘干设备-热泵烘干机_广东雄贵能源设备有限公司 | 京港视通报道-质量走进大江南北-京港视通传媒[北京]有限公司 | 北京燃气公司 用户服务中心 | 防火板_饰面耐火板价格、厂家_品牌认准格林雅 | 济宁工业提升门|济宁电动防火门|济宁快速堆积门-济宁市统一电动门有限公司 | 展厅设计公司,展厅公司,展厅设计,展厅施工,展厅装修,企业展厅,展馆设计公司-深圳广州展厅设计公司 | 焊接烟尘净化器__焊烟除尘设备_打磨工作台_喷漆废气治理设备 -催化燃烧设备 _天津路博蓝天环保科技有限公司 | 磨煤机配件-高铬辊套-高铬衬板-立磨辊套-盐山县宏润电力设备有限公司 | TPE塑胶原料-PPA|杜邦pom工程塑料、PPSU|PCTG材料、PC/PBT价格-悦诚塑胶 | 河南砖机首页-全自动液压免烧砖机,小型砌块水泥砖机厂家[十年老厂] | 量子管通环-自清洗过滤器-全自动反冲洗过滤器-沼河浸过滤器 | 长沙广告公司|长沙广告制作设计|长沙led灯箱招牌制作找望城湖南锦蓝广告装饰工程有限公司 | 昆明网络公司|云南网络公司|昆明网站建设公司|昆明网页设计|云南网站制作|新媒体运营公司|APP开发|小程序研发|尽在昆明奥远科技有限公司 | 全自动贴标机-套标机-工业热风机-不干胶贴标机-上海厚冉机械 | 酶联免疫分析仪-多管旋涡混合仪|混合器-莱普特科学仪器(北京)有限公司 | 氧化铝球_高铝球_氧化铝研磨球-淄博誉洁陶瓷新材料有限公司 | 福州仿石漆加盟_福建仿石漆厂家-外墙仿石漆加盟推荐铁壁金钢(福建)新材料科技有限公司有保障 | 便携式谷丙转氨酶检测仪|华图生物科技百科 | 定制异形重型钢格栅板/钢格板_定做踏步板/排水沟盖板_钢格栅板批发厂家-河北圣墨金属制品有限公司 | 西宁装修_西宁装修公司-西宁业之峰装饰-青海业之峰墅级装饰设计公司【官网】 | SRRC认证_电磁兼容_EMC测试整改_FCC认证_SDOC认证-深圳市环测威检测技术有限公司 | 天津热油泵_管道泵_天津高温热油泵-天津市金丰泰机械泵业有限公司【官方网站】 | 高精度-恒温冷水机-螺杆式冰水机-蒸发冷冷水机-北京蓝海神骏科技有限公司 | 网架支座@球铰支座@钢结构支座@成品支座厂家@万向滑动支座_桥兴工程橡胶有限公司 | 吊篮式|移动式冷热冲击试验箱-二槽冷热冲击试验箱-广东科宝 | 根系分析仪,大米外观品质检测仪,考种仪,藻类鉴定计数仪,叶面积仪,菌落计数仪,抑菌圈测量仪,抗生素效价测定仪,植物表型仪,冠层分析仪-杭州万深检测仪器网 | 气动球阀_衬氟蝶阀_调节阀_电动截止阀_上海沃托阀门有限公司 | 垃圾处理设备_餐厨垃圾处理设备_厨余垃圾处理设备_果蔬垃圾处理设备-深圳市三盛环保科技有限公司 | 飞象网 - 通信人每天必上的网站 全球化工设备网—化工设备,化工机械,制药设备,环保设备的专业网络市场。 | 翰墨AI智能写作助手官网_人工智能问答在线AI写作免费一键生成 | 无硅导热垫片-碳纤维导热垫片-导热相变材料厂家-东莞市盛元新材料科技有限公司 | 北京四合院出租,北京四合院出售,北京平房买卖 - 顺益兴四合院 | 心肺复苏模拟人|医学模型|急救护理模型|医学教学模型上海康人医学仪器设备有限公司 | 航拍_专业的无人机航拍摄影门户社区网站_航拍网 | 冷却塔改造厂家_不锈钢冷却塔_玻璃钢冷却塔改造维修-广东特菱节能空调设备有限公司 | 上海小程序开发-小程序制作-上海小程序定制开发公司-微信商城小程序-上海咏熠 | 舞台木地板厂家_体育运动木地板_室内篮球馆木地板_实木运动地板厂家_欧氏篮球地板推荐 | 中药超微粉碎机(中药细胞级微粉碎)-百科 |