亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

解決vue中el-tab-pane切換的問題

瀏覽:3日期:2023-01-03 15:18:44

今天在編寫vue的時候用到了el-tabs,然后遇到切換的時候,在次打開el-dialog還是上次的狀態(因為兩次打開的el-tab-pane數量不一樣,就出現了問題)

如下:

解決vue中el-tab-pane切換的問題

第一次打開時的狀態,打開到第二次的時候

解決vue中el-tab-pane切換的問題

解決方法

給el-tab-pane命名

<el-tabs type='border-card' v-model='activeName' ></el-tabs>

在script中

data() { return { isShow: ’’, activeName:’second’ } },

在每次關閉彈框的時候,在關閉方法中重置activeName

activeName=’second’

補充知識:vue + element-ui 制作tab切換(切換vue組件,踩坑總結)

項目中用到了一個頁面要實現tab切換實現報表展示,自行百度了一下;最后實現效果,在這里把步驟分享給大家!

創建文件:

tabZujian.vue

<template> <div class='tabZujian'> <el-tabs v-model='activeName'> <el-tab-pane label='tab1' name='first' :key='’first’'><child1></child1> </el-tab-pane><el-tab-pane label='tab2' name='second' :key='’second’'><child2></child2></el-tab-pane> </el-tabs> </div></template> <script>import tabZujianChild1 from ’@/tabComponents/tabZujianChild1’import tabZujianChild2 from ’@/tabComponents/tabZujianChild2’export default { name: ’tabZujian’, components:{ child1:tabZujianChild1, child2:tabZujianChild2 }, data() { return { //默認第一個選項卡 activeName: 'first', } }, mounted(){ }}</script>

tabZujianChild1.vue

<template> <div class='child1'> 我是第一個自組件 </div></template><script> export default { name: ’child1’, mounted(){ console.log('tab1組件') } }</script>

tabZujianChild2.vue

<template> <div class='child2'> 我是第二個子組件 </div></template> <script> export default { name: ’child1’, mounted(){ console.log('tab2組件') } }</script>

解決vue中el-tab-pane切換的問題

問題解決:

其實這個問題解決起來非常簡單,我們想要的是每次切換tab都能夠讓對應的tab子組件進行重新渲染。

初始化兩個變量 isChildUpdate1:true,isChildUpdate2:false;

使用v-if控制child1和child2是否渲染。

每次切換tab選項的時候,觸發事件。讓當前點擊的tab變量設置位true,讓當前組件重新渲染。

這時候當你來回切換的時候,通過v-if判斷是否重新渲染當前組件

更改一下tabZujian.vue

<template> <div class='tabZujian'><el-tabs v-model='activeName' @tab-click='handleClick'> <el-tab-pane label='tab1' name='first' :key='’first’'><child1 v-if='isChildUpdate1'></child1> </el-tab-pane><el-tab-pane label='tab2' name='second' :key='’second’'><child2 v-if='isChildUpdate2'></child2></el-tab-pane> </el-tabs> </div></template> <script>import tabZujianChild1 from ’@/tabComponents/tabZujianChild1’import tabZujianChild2 from ’@/tabComponents/tabZujianChild2’export default { name: ’tabZujian’, components:{ child1:tabZujianChild1, child2:tabZujianChild2 }, data() { return { //默認第一個選項卡 activeName: 'first', isChildUpdate1:true, isChildUpdate2:false } }, mounted(){ }, methods:{ handleClick(tab) { if(tab.name == 'first') {this.isChildUpdate1 = true;this.isChildUpdate2 = false; } else if(tab.name == 'second') {this.isChildUpdate1 = false;this.isChildUpdate2 = true; } } }}</script>

最后成功了。

以上這篇解決vue中el-tab-pane切換的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 亚洲黄色第一页 | 亚洲a在线观看 | 日韩片在线观看 | 大尺度做爰视频吃奶www | 丁香婷婷激情网 | 一级做a爰片性色毛片视频图片 | 一区二区三区视频网站 | 亚洲精品久久久久中文字小说 | 国产午夜视频在线观看 | 久久精品综合国产二区 | 国产精品高清视亚洲乱码 | 国产一区二区在线免费观看 | 日韩欧美一区二区久久 | 在线视频欧美日韩 | 一级特黄视频 | 国产免费久久精品99re丫y | 免费一级欧美在线观看视频片 | 美女黄色在线观看 | 亚洲欧美国产精品久久久 | 欧美一级毛片做受 | 一区二区三区在线免费观看视频 | 131美女爱做免费高清视频 | 丁香六月婷婷综合 | 无码免费一区二区三区免费播放 | 最新永久一路线二路线三路线 | 1024国产基地 | 国产一区在线免费观看 | 日韩毛片欧美一级a网站 | 精品国产第一国产综合精品gif | 日本亚洲精品色婷婷在线影院 | 琪琪五月天综合婷婷 | 国产精品久久久久不卡绿巨人 | 在线免费三级 | 免费高清资源黄网站在线观看 | 生活片一级播放免费 | 高清国产美女一级a毛片在线 | 国产小视频免费 | 成人免费aa在线观看 | 欧美国产日韩精品 | 国产精品lululu在线观看 | 亚洲综合色区图片区 |