欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

VUE前后端學習tab寫法實例

 更新時間:2019年08月06日 15:55:13   作者:陽光男孩  
在本篇文章里小編給大家分享了關于VUE前后端學習tab寫法實例以及相關知識點,需要的朋友們參考下。

動態(tài)創(chuàng)建一個tab,里面放一個table,這樣一個后臺管理的基本功能(之一)就出來了。

好吧,這里其實只是試試水,感受一下vue的數(shù)據(jù)驅(qū)動可以怎么玩,通過一個個實例學習一下vue的各個知識點。這里要看看方法和css如何設置。

一、目標

1、  可以動態(tài)創(chuàng)建tab。

2、  可以切換(廢話)、可以關閉tab。

3、  Css的設置。

4、  方法的處理方式。

5、  效果圖

 

二、思路

應該有好多種方式可以實現(xiàn),這里先試一個,其他的以后再說。

還是數(shù)據(jù)驅(qū)動,那么就建立一個大的數(shù)據(jù)包,把tab信息和table信息都放進去,然后綁定就好了。似乎不是太難的樣子。Emmmmmm大概是吧。

Tab切換,暫時使用css的方式來控制。

關閉tab,就是干掉對應的數(shù)據(jù)。

三、設計與編碼 1.    數(shù)據(jù)包

var tab = new Vue({
    el: '#tab',
    data: {
      tabNumber: 1,    //標簽數(shù)量,這個是臨時的,便于自動重新綁定
      currentTabId: 1,  //當前激活的tab的id
      beforeTabId: 1,   //上一個被激活的tab的id
      tabs: {
        tab1: { //可以有多個標簽,這里先默認一個tab
          id: "1", //標簽識別標示
          title: "我的桌面",
          isShow:true,    //是否顯示
          message: '桌面',
          orderBy: [], //可以控制字段的先后順序,想調(diào)整列的先后順序,改這個數(shù)組就行,可以做個性化設置
          tableTh: {}, //表頭的描述信息
          dataList: [] //數(shù)據(jù)包,字段名作為關鍵字,便于列的調(diào)整先后順序
        }
      }
    },
    methods: {
      tabClick: function (id) {
        //切換tab
        //alert("切換tab" + id);
        //隱藏當前的tab
        var oldId = tab.currentTabId; //記錄切換前tab的id
        tab.beforeTabId = oldId;
        tab.tabs["tab" + oldId].isShow = false; //隱藏切換前的tab

        tab.currentTabId = id; //記錄切換后的id
        tab.tabs["tab" + id].isShow = true; //顯示切換后的tab
   
      },
      closeTab: function (id) {
        if (id === "1") {
          alert("這是桌面,建議不要關閉哦:)");
          return;
        }
        
        delete tab.tabs["tab" + id]; //這種方式不會被vue監(jiān)控到,所以不會觸發(fā)視圖的刷新
        tab.tabNumber = tab.tabNumber - 1; //這樣子湊合一下。觸發(fā)視圖的刷新

        //設置“激活”狀態(tài)
        var oldId = tab.beforeTabId; //上一個激活tab
        var nowId = tab.currentTabId; //現(xiàn)在激活tab

        if (nowId === id) {
          //關掉的是激活tab,需要設置上一個tab為激活狀態(tài)
          tab.currentTabId = oldId;
          tab.tabs["tab" + oldId].isShow = true; //這么寫好像可以觸發(fā)視圖的刷新
          tab.beforeTabId = 1;
        }
        else if (oldId === id) {
          //關閉的是上一個激活tab,修改前一個tab的id
          tab.beforeTabId = 1;
           
        }else {
          //需要強制修改一下,否則不會刷新,emmm,好吧還是沒自動刷新
          tab.currentTabId = nowId;
        }
       }
    }
});

 methods 這個也是一個保留字(關鍵字),就是放方法的。里面可以有多個方法,方法名稱和標簽里的v-on:XXXX='00000' 對應。

這里寫了兩個方法,一個是切換tab的,一個是關閉tab的。

切換tab:按照數(shù)據(jù)驅(qū)動視圖的思路,在方法里面改變數(shù)據(jù)的isShow 屬性值,然后通過模板的設置來實現(xiàn)切換效果。

關閉tab:干掉對應的數(shù)據(jù)即可,只是實現(xiàn)的時候遇到點小問題,delele的方式不能被監(jiān)控,到時視圖不能及時更新,所以加了一個tab數(shù)量的屬性,關掉一個tab,數(shù)量-1,這樣數(shù)據(jù)變化就可以被監(jiān)控到了,然后一起重新綁定。

 2.    模板

<div>
  <!--tab標簽-->
  <ul class="tabs left">
    <li v-for="t in tabs" v-bind:class="{'selectTag':t.isShow}">
      <a v-on:click="tabClick(t.id)" href="javascript:void(0)" rel="external nofollow" > {{t.title}}&nbsp;
        <em class="arrup" v-on:click.stop="closeTab(t.id)">x</em>
      </a>
    </li>
  </ul>

  <div v-for="t in tabs" v-show="t.isShow">
    {{ t.message }}{{tabNumber}}
    <table class="table_default1" v-show="t.message!=='桌面'">
      <tr>
        <th>序號</th>
        <th v-for="key in t.orderBy">
          {{t.tableTh[key].title}}
        </th>
      </tr>
      <tr v-for="(tr,i) in t.dataList">
        <td>{{i+1}}</td>
        <td v-for="index in t.orderBy" v-bind:align="t.tableTh[index].align">
          {{tr[index]}}
        </td>

      </tr>
    </table>
  </div>
</div>

 切換tab

用v-show的方法來控制div是否顯示。

v-show是通過修改style的屬性來實現(xiàn)的。

用v-bind:class="{'selectTag':t.isShow}" 的方式來實現(xiàn)tab的激活效果。

v-bind:class 可以綁定css名稱。因為css名稱總是要被換來換去的,所以vue就很貼心的提供了這種if true 才設置的方式,冒號后面為真,才會設置設個css名稱,這樣數(shù)據(jù)驅(qū)動的時候就方便多了。

 四、運行效果

調(diào)試了半天,好吧上年紀了,思維不夠敏捷,這么點邏輯問題就卡住了,哎。

不過最后還是調(diào)試成功了。

五、總結

這個有一個明顯的問題,這個數(shù)據(jù)包是不是有點大,創(chuàng)建的tab越多,數(shù)據(jù)包就越大,有沒有性能問題?會不會卡?

另外這還只是table,如果增加了按鈕、查詢條件、分頁控件,這個數(shù)據(jù)包的結構要變成多復雜呀?挖坑也不帶這么挖的呀。

那么怎么辦呢?下次再說。(好吧,現(xiàn)在還沒想好,似乎要寫組件,或者要用到插槽)感謝大家對腳本之家的支持。

相關文章

  • 配置vue全局方法的兩種方式實例

    配置vue全局方法的兩種方式實例

    vue項目中有一些方法需要在多個頁面調(diào)用,但為了避免在每個頁面都import進來,可以把方法加到原型上去,這樣在每個組件中都能使用了,下面這篇文章主要給大家介紹了關于配置vue全局方法的兩種方式,需要的朋友可以參考下
    2021-09-09
  • 解決ElementUI組件中el-upload上傳圖片不顯示問題

    解決ElementUI組件中el-upload上傳圖片不顯示問題

    這篇文章主要介紹了解決ElementUI組件中el-upload上傳圖片不顯示問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue2 中使用 render 函數(shù)編寫組件的方式

    vue2 中使用 render 函數(shù)編寫組件的方式

    vue提供了聲明式編寫UI的方式,即vue提供了對DOM進行描述的方式,有兩種描述DOM的方式即模板和render 函數(shù),本文通過示例代碼介紹vue2 中使用 render 函數(shù)編寫組件的方式,感興趣的朋友跟隨小編一起看看吧
    2024-06-06
  • Vue封裝全局過濾器Filters的步驟

    Vue封裝全局過濾器Filters的步驟

    這篇文章主要介紹了Vue封裝全局過濾器Filters的步驟,通過封裝vue全局過濾器實現(xiàn)filters的統(tǒng)一管理。感興趣的朋友可以了解下
    2020-09-09
  • Vue DPlayer詳細使用教程含遇到坑

    Vue DPlayer詳細使用教程含遇到坑

    Vue-DPlayer是一個易于使用、高性能的基于Vue.js的視頻播放器組件,本文給大家介紹Vue DPlayer詳細使用,本文將從四個方面對Vue-DPlayer進行詳細的闡述,感興趣的朋友一起看看吧
    2023-10-10
  • vue-quill-editor富文本編輯器上傳視頻功能詳解

    vue-quill-editor富文本編輯器上傳視頻功能詳解

    需求需要實現(xiàn)富文本的功能,同時富文本中還可以上傳視頻和圖片,選來選去最后決定了用這個富文本編輯器,下面這篇文章主要給大家介紹了關于vue-quill-editor富文本編輯器上傳視頻功能的相關資料,需要的朋友可以參考下
    2023-05-05
  • 詳解Vue中使用v-for語句拋出錯誤的解決方案

    詳解Vue中使用v-for語句拋出錯誤的解決方案

    本篇文章主要介紹了詳解Vue中使用v-for語句拋出錯誤的解決方案,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • 關于Vue新搭檔TypeScript快速入門實踐

    關于Vue新搭檔TypeScript快速入門實踐

    這篇文章主要介紹了關于Vue新搭檔TypeScript快速入門實踐,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue.js實現(xiàn)點擊后動態(tài)添加class及刪除同級class的實現(xiàn)代碼

    vue.js實現(xiàn)點擊后動態(tài)添加class及刪除同級class的實現(xiàn)代碼

    這篇文章主要介紹了vue.js實現(xiàn)點擊后動態(tài)添加class及刪除同級class的相關資料,需要的朋友可以參考下
    2018-04-04
  • 在vue中添加Echarts圖表的基本使用教程

    在vue中添加Echarts圖表的基本使用教程

    雖然老早就看過很多echarts的例子, 但自己接觸的項目中一直都沒有真正用到過,直到最近才開始真正使用,下面這篇文章主要給大家介紹了關于在vue中添加Echarts圖表的基本使用教程,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下。
    2017-11-11

最新評論