国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

使用vue-router與v-if實現(xiàn)tab切換遇到的問題及解決方法

2019-11-19 13:00:27
字體:
供稿:網(wǎng)友

vue-router 該如何使用

忽然碰到一個常見的問題,明明可以使用 v-if / v-show 可以的解決的問題,有沒有必要是使用 vue-router來解決。 比如常見的 tab 切換。一時間,我有些猶豫了,有沒有必要濫用 vue-router。那到底何時用才叫合理呢?

先上代碼,用兩種方式實現(xiàn)的效果

使用vue-router

router

import Tab1 from './components/tab/TabOne'import Tab2 from './components/tab/TabTwo'import Tab3 from './components/tab/TabThree'import Tab4 from './components/tab/TabFour'const routes = [ {path: '/tab1', component: Tab1}, {path: '/tab2', component: Tab2}, {path: '/tab3', component: Tab3}, {path: '/tab4', component: Tab4},]const router = new VueRouter({ routes})

.vue 文件中

<div class="tab"> <router-link to="/tab1">tab1</router-link> <router-link to="/tab2">tab2</router-link> <router-link to="/tab3">tab3</router-link> <router-link to="/tab4">tab4</router-link> <router-view></router-view></div>

使用 v-if/v-show

.vue

<div class="tab"> <button @click="handleTab(1)">tab1</button> <button @click="handleTab(2)">tab2</button> <button @click="handleTab(3)">tab3</button> <button @click="handleTab(4)">tab4</button> <div v-if="isShow === 1"><Tab1 /></div> <div v-if="isShow === 2"><Tab2 /></div> <div v-if="isShow === 3"><Tab3 /></div> <div v-if="isShow === 4"><Tab4 /></div></div>/** * script */ data () {  return {   isShow: 1  } }, methods: {  handleTab (v) {   this.isShow = v  } }

效果如下

  • 上方為路由
  • 下方為v-if

目前看起來效果一致。那就從另一個角度考慮,頁面結(jié)構(gòu)。

vue-router

v-if

總結(jié):

  • 目前看起來,效果沒有很大區(qū)別,代碼量也沒有減少
  • 使用原生,可能是用索引進行關(guān)聯(lián),在vue中推薦使用 數(shù)據(jù)進行驅(qū)動
  • 暫且記錄一筆,以待后期繼續(xù)研究

以上所述是小編給大家介紹的vue-router與v-if實現(xiàn)tab切換的思考,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對武林網(wǎng)網(wǎng)站的支持!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 清苑县| 铜陵市| 顺平县| 新干县| 项城市| 钟祥市| 图木舒克市| 交口县| 靖安县| 徐水县| 荥阳市| 尼勒克县| 东乌| 二手房| 阜宁县| 海门市| 双城市| 沁源县| 克拉玛依市| 望城县| 弋阳县| 天峻县| 化州市| 长兴县| 奉节县| 仪征市| 伊川县| 壤塘县| 保亭| 宁都县| 雷波县| 准格尔旗| 福海县| 镇平县| 白河县| 锦屏县| 新密市| 岳阳县| 礼泉县| 呼和浩特市| 师宗县|