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

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

vue實現tab標簽(標簽超出自動滾動)

瀏覽:36日期:2022-09-29 11:57:54

當創建的tab標簽超出頁面可視區域時自動滾動一個tab標簽距離,并可手動點擊滾動tab標簽,實現效果請看GIF圖

效果預覽GIF圖

vue實現tab標簽(標簽超出自動滾動)

<template> <div class='main-box'><button @click='add'>添加</button><div class='main-box-tab'> <i @click='previous'><<</i> <i @click='next'>>></i> <div ref='tabs'><div class='main-box-tab-roll'> <div v-for='(item,index) in tabs' :key='index' : @click.stop='clickTab(item.name,index)'><span>{{item.meta.title}}</span><i @click.stop='close(item.name)'></i> </div></div> </div></div><div class='main-box-content'> <div>{{actionName}}</div></div> </div></template><script> export default {name: 'index',data() { return {tabs: [],moveX: 0,count: 1,unoccupied: 0,tabsCount: 0,actionName: ’test1’ }},watch: { actionName(val) {let len = this.tabs.length// 如有重復數據退出后續函數執行for (let i = 0; i < len; i++) { if (this.tabs[i].name === val) {this.$nextTick(() => { this.translateX((i + 1 - this.tabsCount) * this.width - this.unoccupied)})return }}this.tabs.push({ name: `test${this.count}`, meta: {title: `test${this.count}` }})this.$nextTick(() => { // (總共有多少個tabs - 未偏移時可見的元素個數) * 單個tab標簽元素長度 - 被遮擋tab元素的可見部分的寬度 this.translateX((this.tabs.length - this.tabsCount) * this.width - this.unoccupied)}) }},mounted() { this.tabs.push({name: `test${this.count}`,meta: { title: `test${this.count}`} }) this.$nextTick(() => {let tabs = this.$refs.tabslet getStyle = getComputedStyle(tabs.children[0].children[0], null)let marginLeft = parseFloat(getStyle.marginLeft.substr(0, getStyle.marginLeft.length - 2))let marginRight = parseFloat(getStyle.marginRight.substr(0, getStyle.marginRight.length - 2))// 元素實際寬度 = 元素的寬度 + 外邊距this.width = marginLeft + marginRight + tabs.children[0].children[0].offsetWidth/** * 以下注釋計算方式用于理解實現邏輯 **/// // 可視區域能放入多少個元素 = 可視區域的寬度 / 子元素實際寬度// let num = tabs.offsetWidth / this.width// // 被遮擋tab元素的可見部分的寬度 = 可見區域的寬度 - (子元素實際寬度 * num轉為整數)// this.unoccupied = tabs.offsetWidth - (this.width * parseInt(num))// 最終精簡為取余(得數跟上面的計算是一樣的)this.unoccupied = tabs.offsetWidth % this.width// 轉為整數this.tabsCount = parseInt(tabs.offsetWidth / this.width) })},methods: { add() {this.count++this.actionName = `test${this.count}` }, /** * 切換tab標簽頁 **/ clickTab(name) {if (this.actionName !== name) { this.actionName = name} }, /** * 關閉tab標簽頁 **/ close(name) {let len = this.tabs.lengthlet jumpName = nullif (len > 1) { for (let i = 0; i < len; i++) {if (this.tabs[i].name === name) { this.tabs.splice(i, 1) jumpName = this.tabs[i ? i - 1 : 0].name if (this.actionName !== jumpName && name === this.actionName) {this.actionName = jumpName } this.$nextTick(() => {this.previous() }) return} }} }, /** * 往右偏移 **/ next() {// scrollWidth獲取不準確// 使用this.width * this.tabs.length計算出總長度let totalWidth = this.width * this.tabs.lengththis.$nextTick(() => { let dom = this.$refs.tabs // 可視區域 < 滾動區域(滾動區域大于可視區域才可以移動) // 移動距離 + 可視區域 = 滾動區域的寬度(上一次的寬度,當點擊時才是實際寬度)< 滾動區域 if (dom.clientWidth < totalWidth && this.moveX + dom.clientWidth < totalWidth) {// this.moveX為0減去空余空間的寬度this.moveX += this.moveX ? this.width : this.width - this.unoccupiedthis.translateX(this.moveX) }}) }, /** * 往左偏移 **/ previous() {if (this.moveX > 0) { this.moveX -= this.width this.translateX(this.moveX)} }, /** * 開始移動dom **/ translateX(x) {this.moveX = x < 0 ? 0 : xthis.$refs.tabs.children[0].style.transform = `translateX(-${this.moveX}px)` }} }</script><style lang='scss' scoped> .main-box {height: 500px;width: 500px;padding: 10px 20px 20px 20px;.main-box-tab { position: relative; padding: 10px 20px; overflow: hidden; & > i {position: absolute;cursor: pointer;bottom: 15px;&:nth-child(1) { left: 0;}&:nth-child(2) { right: 0;} } .main-box-tab-content {overflow: hidden;.main-box-tab-roll { transition: transform .5s; display: flex; align-items: center; div {flex-shrink: 0;cursor: pointer;width: 130px;height: 25px;margin: 0 5px;display: flex;align-items: center;justify-content: space-between;span, i { font-size: 12px;}span { margin-left: 10px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis;}i { margin-right: 10px;} }} } .tab-item {color: #cccccc;background-color: rgba(255, 255, 255, .5);border-radius: 0 1px 0 1px;border: 1px solid #052141; } .tab-item-action {color: #ffffff;background: rgba(0, 180, 255, 0.8);border-radius: 0 1px 0 1px;border: 1px solid #1E2088; }}.main-box-content { height: calc(100% - 70px); padding: 10px; border: 1px saddlebrown solid; background-size: 100% 100%;} }</style>

到此這篇關于vue實現tab標簽(標簽超出自動滾動)的文章就介紹到這了,更多相關vue tab標簽 內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲一区中文| 国产精品婷婷| 日韩综合一区| 欧美 日韩 国产精品免费观看| 午夜宅男久久久| 69堂免费精品视频在线播放| 国产a亚洲精品| 欧美在线亚洲| 欧美亚洲国产日韩| 麻豆视频一区二区| 欧美日韩免费观看视频| 蜜桃久久av一区| 美女久久99| 欧美日韩国产探花| 欧美日韩亚洲三区| 在线手机中文字幕| 免费在线观看精品| 久久精品二区亚洲w码| 2023国产精品久久久精品双| 国产精品一页| 香蕉国产精品| 国产精品中文字幕亚洲欧美| 欧美亚洲精品在线| 欧美精品中文| 久久一级电影| 国产精品久一| 亚洲深爱激情| 精品久久久久久久| 中文字幕亚洲精品乱码| 国产精品专区免费| 日本国产欧美| 亚洲一级网站| 国产一区二区三区黄网站| 免费精品视频最新在线| 91亚洲国产| 日韩不卡一二三区| 亚洲精品小说| 在线天堂中文资源最新版| 日韩高清不卡一区二区| av一区在线| 国产精品久久久久久久久久妞妞 | 视频在线在亚洲| 国产一区二区三区黄网站 | 亚洲精品在线国产| 欧美影院三区| 国产一区二区三区久久| 日韩成人在线看| 99成人在线| 狠狠躁少妇一区二区三区| 麻豆9191精品国产| 色在线视频观看| 国产精品嫩草影院在线看| 亚洲欧美日韩国产综合精品二区| 四虎8848精品成人免费网站 | 欧美激情福利| 日本亚洲最大的色成网站www | 亚洲丝袜美腿一区| 波多视频一区| 欧美精品aa| 亚洲va久久| 亚洲欧美成人综合| 日韩在线综合| 国产aⅴ精品一区二区三区久久| 日韩av影院| 亚洲香蕉视频| 午夜亚洲一区| 欧美特黄一区| 国产91精品对白在线播放| 欧美激情另类| 精品中文字幕一区二区三区四区| 日韩欧美2区| 三级久久三级久久久| 久久国产99| 国产亚洲一区在线| 偷拍欧美精品| 欧美成人日韩| 夜鲁夜鲁夜鲁视频在线播放| 精品一区二区三区中文字幕| 国产精品一线| 国产日韩在线观看视频| 日本aⅴ免费视频一区二区三区| 亚洲永久精品唐人导航网址| 丝袜美腿亚洲一区| 久久av一区| 六月婷婷一区| 亚洲图片久久| 日韩午夜视频在线| 亚洲精品影视| 日韩高清二区| 国产欧美二区| 麻豆视频一区二区| 韩国女主播一区二区三区| 高清久久一区| 日韩精品永久网址| 99久久婷婷这里只有精品| 亚洲黑丝一区二区| 91精品福利| 美女精品在线观看| 亚洲精品伊人| 日本va欧美va精品发布| 欧美一区免费| 麻豆国产精品视频| 成人免费一区| 色偷偷色偷偷色偷偷在线视频| 日韩在线观看一区| 久久久久午夜电影| 国产精品97| 国产亚洲毛片| 日韩有吗在线观看| 国产精品久久久久久久久久齐齐| 麻豆精品久久| 在线中文字幕播放| 国产精品7m凸凹视频分类| 久久亚洲美女| 日本国产欧美| 精品国产乱码久久久| 亚洲精品一区三区三区在线观看| 欧美久久天堂| 狠狠色综合网| 日韩精彩视频在线观看| 国产剧情在线观看一区| 国产成人精品亚洲线观看| 久久精品国产亚洲夜色av网站| 国产精品毛片在线| 欧美另类中文字幕| 国产精品久久久久久久免费观看| 91精品蜜臀一区二区三区在线 | 97精品资源在线观看| 麻豆精品视频在线观看视频| 欧美香蕉视频| 免费欧美在线视频| 久久99精品久久久久久园产越南 | 三级欧美在线一区| 国产精品黄网站| 性感美女一区二区在线观看| 国产精品日本| 国产伦乱精品| 久久久蜜桃一区二区人| 免费美女久久99| 国产欧美日韩一区二区三区四区| 精品国产欧美| 欧美日韩国产综合网| 日韩高清在线观看一区二区| 成人在线视频免费看| 亚洲免费成人| 国产欧美日本| 在线成人动漫av| 日本视频一区二区| 日韩欧美精品| 天堂av一区| 欧美天堂视频| 日韩三级一区| 桃色一区二区| 日韩精品久久久久久| 精品国产成人| 欧美综合国产| 欧美激情另类| 亚洲精品乱码日韩| www.九色在线| 日本在线观看不卡视频| 日韩精品dvd| 日本午夜精品久久久久| 久久精品在线| 久久国际精品| 99xxxx成人网| 国产一区丝袜| 亚洲va久久久噜噜噜久久| 欧美二三四区| 欧美日本二区| 久久精品国产68国产精品亚洲| 日本不卡一区二区| 欧美日韩精品免费观看视欧美高清免费大片| 蜜乳av另类精品一区二区| 高清久久一区| 日韩不卡一二三区| 欧美午夜不卡| 精品一区视频| 亚洲精品日本| 亚洲一级特黄| 久久一区国产| 日韩精品a在线观看91| 极品日韩av| 91欧美在线| 久久av网址| 亚洲视频电影在线| 欧美a级片一区| 天堂中文av在线资源库| 国产精品99久久免费观看| 亚洲人亚洲人色久| 日韩一区二区久久| 日韩精品免费一区二区在线观看 | 激情自拍一区| 国产不卡av一区二区| 日本精品国产| 丝袜国产日韩另类美女| 欧美在线观看视频一区| 精品视频网站| 欧美精品三级在线| 天堂va欧美ⅴa亚洲va一国产| 午夜久久美女|