Vue可左右滑動(dòng)按鈕組組件使用詳解
本文實(shí)例為大家分享了基于Vue可左右滑動(dòng)按鈕組組件,供大家參考,具體內(nèi)容如下
左右兩箭頭控制按鈕組左右移動(dòng),雙擊到最左或最右邊,功能比較簡(jiǎn)單。如下所示
<template> ?? ?<div class="demoButtons"> ?? ??? ?<div class="buttonF"> ?? ??? ??? ?<el-row style="height:30px "> ?? ??? ??? ??? ?<el-col class="lableI"><i class="el-icon-arrow-left " @click="moveButtons('left')" @dblclick="moveSide('left')" /></el-col> ?? ??? ??? ??? ?<el-col ref="buttonBody" class="buttonBody"> ?? ??? ??? ??? ??? ?<el-row id="buttonRow" ref="buttonRow"> ?? ??? ??? ??? ??? ??? ?<el-tag :style="{'width':buttonWidth+'px'}" v-for="(item, index) in buttonData" :key="index" :type="index == clickIndex ? '' : 'info'" @click="resetData(index, item)"> ?? ??? ??? ??? ??? ??? ??? ?<el-tooltip v-if="item.name && item.name.length > ?parseInt(buttonWidth/12) - 1" placement="top" :content="item.name" effect="light"> ?? ??? ??? ??? ??? ??? ??? ??? ?<span>{{ ?resetName(item.name) }}</span> ?? ??? ??? ??? ??? ??? ??? ?</el-tooltip> ?? ??? ??? ??? ??? ??? ??? ?<span v-else>{{ item.name }}</span> ?? ??? ??? ??? ??? ??? ?</el-tag> ?? ??? ??? ??? ??? ?</el-row> ?? ??? ??? ??? ?</el-col> ?? ??? ??? ??? ?<el-col class="lableI"><i class="el-icon-arrow-right " @click="moveButtons('right')" @dblclick="moveSide('right')" /></el-col> ?? ??? ??? ?</el-row> ?? ??? ?</div> ?? ?</div> </template> <script> import $ from 'jquery' export default { ?? ?props: { ?? ??? ?buttonData: { ?? ??? ??? ?type: Array, ?? ??? ??? ?default: () => { ?? ??? ??? ??? ?return [] ?? ??? ??? ?} ?? ??? ?}, ?? ??? ?buttonWidth: { ?? ??? ??? ?type: Number, ?? ??? ??? ?default: 62 ?? ??? ?} ?? ?}, ?? ?data () { ?? ??? ?return { ?? ??? ??? ?clickIndex: 0, ?? ??? ??? ?currentSite: 0, ?? ??? ??? ?showCount: 0, ?? ??? ??? ?clickTimer: null, ?? ??? ?} ?? ?}, ?? ?watch: {}, ?? ?created () { ?? ??? ?// this.setButtons() ?? ?}, ?? ?mounted () { ?? ??? ?this.$nextTick(() => { ?? ??? ??? ?this.showCount = parseInt(this.$refs.buttonBody.$el.clientWidth / this.buttonWidth) // 一行能展示幾個(gè)按鈕 ?? ??? ?}) ?? ?}, ?? ?methods: { ?? ??? ?//設(shè)置名字 ?? ??? ?resetName (val) { ?? ??? ??? ?let i = parseInt(this.buttonWidth / 12) - 1; ?? ??? ??? ?if (val && val.length > i) { ?? ??? ??? ??? ?return val.slice(0, i) ?? ??? ??? ?} else { ?? ??? ??? ??? ?return val ?? ??? ??? ?} ?? ??? ?}, ?? ??? ?// 單擊移一格 ?? ??? ?moveButtons (val) { ?? ??? ??? ?if (this.clickTimer) { ?? ??? ??? ??? ?window.clearTimeout(this.clickTimer) ?? ??? ??? ??? ?this.clickTimer = null ?? ??? ??? ?} ?? ??? ??? ?this.clickTimer = window.setTimeout(() => { ?? ??? ??? ??? ?this.$nextTick(() => { ?? ??? ??? ??? ??? ?if (val == 'left') { ?? ??? ??? ??? ??? ??? ?if (this.currentSite < 0) { ?? ??? ??? ??? ??? ??? ??? ?this.currentSite = this.currentSite + this.buttonWidth ?? ??? ??? ??? ??? ??? ?} ?? ??? ??? ??? ??? ?} else { ?? ??? ??? ??? ??? ??? ?const totalCount = this.buttonData.length // 總共幾個(gè)按鈕 ?? ??? ??? ??? ??? ??? ?const showIndex = -parseInt(this.currentSite / this.buttonWidth) // 向左移了幾個(gè)按鈕 ?? ??? ??? ??? ??? ??? ?console.log(totalCount, 'totalLength', this.showCount, showIndex) ?? ??? ??? ??? ??? ??? ?if (showIndex + this.showCount < totalCount) { ?? ??? ??? ??? ??? ??? ??? ?this.currentSite = this.currentSite - this.buttonWidth ?? ??? ??? ??? ??? ??? ?} ?? ??? ??? ??? ??? ?} ?? ??? ??? ??? ??? ?$('#buttonRow').animate({ marginLeft: this.currentSite + 'px' }) ?? ??? ??? ??? ?}) ?? ??? ??? ?}, 300) ?? ??? ?}, ?? ??? ?// 雙擊到邊 ?? ??? ?moveSide (val) { ?? ??? ??? ?if (this.clickTimer) { ?? ??? ??? ??? ?window.clearTimeout(this.clickTimer) ?? ??? ??? ??? ?this.clickTimer = null ?? ??? ??? ?} ?? ??? ??? ?this.$nextTick(() => { ?? ??? ??? ??? ?if (val == 'left') { ?? ??? ??? ??? ??? ?this.currentSite = 0 ?? ??? ??? ??? ?} else { ?? ??? ??? ??? ??? ?const totalCount = this.buttonData.length // 總共幾個(gè)按鈕 ?? ??? ??? ??? ??? ?if (totalCount > this.showCount) { ?? ??? ??? ??? ??? ??? ?this.currentSite = -((totalCount - this.showCount) * this.buttonWidth) ?? ??? ??? ??? ??? ?} ?? ??? ??? ??? ?} ?? ??? ??? ??? ?$('#buttonRow').animate({ marginLeft: this.currentSite + 'px' }) ?? ??? ??? ?}) ?? ??? ?}, ?? ??? ?setButtons (data) { ?? ??? ??? ?this.buttonData = data ?? ??? ?}, ?? ??? ?resetData (index, data) { ?? ??? ??? ?this.clickIndex = index ?? ??? ??? ?this.$emit('resetData', data) ?? ??? ?} ?? ?} } </script> <style lang="scss" scoped> .demoButtons { ?? ?width: 100%; ?? ?height: 100%; } .buttonF { ?? ?width: 100%; ?? ?margin: 0 auto; ?? ?height: 30px; ?? ?line-height: 30px; } .lableI { ?? ?height: 30px; ?? ?line-height: 30px; ?? ?width: 20px; ?? ?cursor: pointer; } .buttonBody { ?? ?overflow: hidden; ?? ?height: 30px; ?? ?line-height: 30px; ?? ?width: calc(100% - 40px); ?? ?white-space: nowrap; } .el-tag { ?? ?text-align: center; ?? ?padding: 0px 8px !important; ?? ?height: 28px; ?? ?line-height: 28px; ?? ?cursor: pointer; ?? ?border-radius: 0px !important; ?? ?overflow: hidden; ?? ?font-size: 12px; } </style>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- vue實(shí)現(xiàn)頂部左右滑動(dòng)導(dǎo)航
- Vue實(shí)現(xiàn)tab導(dǎo)航欄并支持左右滑動(dòng)功能
- vue實(shí)現(xiàn)左右滑動(dòng)效果實(shí)例代碼
- vue+swiper實(shí)現(xiàn)左右滑動(dòng)的測(cè)試題功能
- vue使用swiper實(shí)現(xiàn)左右滑動(dòng)切換圖片
- vue使用better-scroll實(shí)現(xiàn)滑動(dòng)以及左右聯(lián)動(dòng)
- vue移動(dòng)端的左右滑動(dòng)事件詳解
- vue移動(dòng)端實(shí)現(xiàn)手機(jī)左右滑動(dòng)入場(chǎng)動(dòng)畫(huà)
- Vue實(shí)現(xiàn)移動(dòng)端左右滑動(dòng)效果的方法
- 基于Vue實(shí)現(xiàn)頁(yè)面切換左右滑動(dòng)效果
相關(guān)文章
vue?eslint報(bào)錯(cuò)error?"Component?name?"*****"
這篇文章主要給大家介紹了關(guān)于vue?eslint報(bào)錯(cuò)error?“Component?name?“*****“?should?always?be?multi-word”的解決方法,文中通過(guò)圖文以及實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09vue-cli3.0 axios跨域請(qǐng)求代理配置方式及端口修改
這篇文章主要介紹了vue-cli3.0 axios跨域請(qǐng)求代理配置方式及端口修改,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10element-plus+Vue3實(shí)現(xiàn)表格數(shù)據(jù)動(dòng)態(tài)渲染
在Vue中,el-table是element-ui提供的強(qiáng)大表格組件,可以用于展示靜態(tài)和動(dòng)態(tài)表格數(shù)據(jù),本文主要介紹了element-plus+Vue3實(shí)現(xiàn)表格數(shù)據(jù)動(dòng)態(tài)渲染,感興趣的可以了解一下2024-03-03Vue封裝一個(gè)簡(jiǎn)單輕量的上傳文件組件的示例
這篇文章主要介紹了Vue封裝一個(gè)簡(jiǎn)單輕量的上傳文件組件的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-03-03詳解如何使用 vue-cli 開(kāi)發(fā)多頁(yè)應(yīng)用
本篇文章主要介紹了詳解如何使用 vue-cli 開(kāi)發(fā)多頁(yè)應(yīng)用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-12-12解決vue打包c(diǎn)ss文件中背景圖片的路徑問(wèn)題
今天小編就為大家分享一篇解決vue打包c(diǎn)ss文件中背景圖片的路徑問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09