成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Element UI table組件源碼分析

妤鋒シ / 1197人閱讀

摘要:本文章從如下圖所示的最基本的入手,分析組件源代碼。本人已經(jīng)對(duì)組件原來(lái)的源碼進(jìn)行削減,源碼點(diǎn)擊這里下載。還有兩個(gè)重要的函數(shù)與。在組件的階段會(huì)調(diào)用更新,從而觸發(fā)重新渲染。例如當(dāng)組件加載后發(fā)送請(qǐng)求,待請(qǐng)求響應(yīng)賦值,重新渲染。

本文章從如下圖所示的最基本的table入手,分析table組件源代碼。本人已經(jīng)對(duì)table組件原來(lái)的源碼進(jìn)行削減,源碼點(diǎn)擊這里下載。本文只對(duì)重要的代碼片段進(jìn)行講解,推薦下載代碼把項(xiàng)目運(yùn)行起來(lái),跟著文章的思路閱讀。

思路

table、table-header、table-body、table-column之間通過(guò)table-store進(jìn)行狀態(tài)管理。table-header、table-body對(duì)table-store數(shù)據(jù)進(jìn)行監(jiān)聽(tīng),每當(dāng)table改變table-store數(shù)據(jù)時(shí)觸發(fā)table-header、table-body重新渲染。

table-column為列數(shù)據(jù)column綁定相應(yīng)的renderCell函數(shù),供table-body渲染時(shí)使用。table-column這個(gè)組件自身不做任何渲染。所以會(huì)看到模板將其隱藏。還有就是table-header、table-body通過(guò)render函數(shù)進(jìn)行渲染。

初始化順序

table

初始化store

data() {
  const store = new TableStore(this);
  return {
    store,
  };
}

將store共享給table-header、table-body

    

將數(shù)據(jù)存儲(chǔ)到store,供table-body獲取data將其渲染

watch: {
    data: {
      immediate: true,
      handler(value) {
        // 供 table-body computed.data 使用 
        this.store.commit("setData", value);
        // ......
      }
    },
},

設(shè)置tableId

created() {
      //.....
      this.tableId = `el-table_${tableIdSeed}`;
      //.....
  }

調(diào)用 updateColumns 觸發(fā) table-header、table-body 二次render更新,標(biāo)記mounted完成

mounted() {
    // .....
    this.store.updateColumns();
    // .....
    this.$ready = true;
}     

table-column

生成column,并為column綁定renderCell函數(shù)供table-body使用

created(){
      // .........
      let column = getDefaultColumn(type, {
          id: this.columnId,
          columnKey: this.columnKey,
          label: this.label,
          property: this.prop || this.property,// 舊版element ui為property,現(xiàn)在的版本是prop
          type, // selection、index、expand
          renderCell: null,
          renderHeader: this.renderHeader, // 提供給table-column, table-column.js line 112
          width,
          formatter: this.formatter,
          context: this.context,
          index: this.index,
        });
      // .........
      
      // 提t(yī)able-body使用, table-body.js line 69
      column.renderCell = function (createElement, data) {
        if (_self.$scopedSlots.default) {
          renderCell = () => _self.$scopedSlots.default(data);
          //
        }
  
        if (!renderCell) {// table-header不渲染index列的走這里,
          /*
王小虎
*/ renderCell = DEFAULT_RENDER_CELL; } // return
{renderCell(createElement, data)}
; }; }

給store.state._columns數(shù)組填充數(shù)據(jù)

mounted() {
    // ...... 
    owner.store.commit("insertColumn", this.columnConfig, columnIndex, this.isSubColumn ? parent.columnConfig : null);
}

table-store

table-store有兩個(gè)很重要的屬性_columns、data,_columns保存列的相關(guān)信息,data則保存開(kāi)發(fā)者傳入的表格數(shù)據(jù)。還有兩個(gè)重要的函數(shù)insertColumn與updateColumns。

insertColumn為_(kāi)columns填充數(shù)據(jù)

TableStore.prototype.mutations = {
  insertColumn(states, column, index, parent) {
    let array = states._columns;
    // ......

    if (typeof index !== "undefined") {
      // 在index的位置插入column
      array.splice(index, 0, column);
    } else {
      array.push(column);
    }

    // .....
  },
}

updateColumns 對(duì)_columns進(jìn)行過(guò)濾得到columns

TableStore.prototype.updateColumns = function() {
  const states = this.states;
  const _columns = states._columns || [];
  
  const notFixedColumns = _columns.filter(column => !column.fixed);
  // .....
  const leafColumns = doFlattenColumns(notFixedColumns);
  // .....
  
  states.columns = [].concat(leafColumns);
  // ....
}

table-header、table-body

table-header、table-body都擁有以下屬性

props: {
    store: {
      required: true
    },
}

computed: {
    columns() {
      return this.store.states.columns;
    },
},

render(){
    // 渲染columns的數(shù)據(jù)
}

這兩個(gè)組件的工作原理是監(jiān)聽(tīng)columns數(shù)據(jù)變化以觸發(fā)render渲染。在table組件的mounted階段會(huì)調(diào)用 updateColumns 更新 columns,從而觸發(fā) table-header、table-body 重新渲染。

另外table-body還會(huì)監(jiān)聽(tīng)data變化,觸發(fā)render。例如當(dāng)組件加載后發(fā)送請(qǐng)求,待請(qǐng)求響應(yīng)賦值data,重新渲染table-body。

  computed: {
    data() {
      // table.vue watch.data 中 調(diào)用 setData 在store 中存儲(chǔ) data
      return this.store.states.data;
    },
  },
參考

Element UI table官方文檔

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/108111.html

相關(guān)文章

  • 源碼Element UI Table組件實(shí)現(xiàn)思路

    摘要:接下來(lái)來(lái)看一下是如何編寫(xiě)一個(gè)組件的,在看源碼之前,首先還是要對(duì)他的組件的大致功能有一個(gè)了解,這樣我們?cè)诳丛创a的時(shí)候才會(huì)知道這一段大概實(shí)現(xiàn)了什么功能。最后我實(shí)現(xiàn)的功能文檔以及最終的一個(gè)樣例 在你實(shí)現(xiàn)一個(gè)組件過(guò)程中,一定要注意一下幾點(diǎn) 將代碼模塊化并且分離。如果你將大量的邏輯或者是代碼都放在鉤子函數(shù)中(比如mounted),那么寫(xiě)出來(lái)的組件代碼將非常丑陋,這樣子寫(xiě)出的代碼也往往難以維護(hù)。...

    moven_j 評(píng)論0 收藏0
  • iview 和 Elemet UI 源碼比較

    摘要:近期給自己立了個(gè)小,讀源碼,每周至少讀篇源碼下面來(lái)談?wù)労瓦@兩個(gè)基于的框架源碼的基本結(jié)構(gòu)以及區(qū)別。例如四兩個(gè)庫(kù)組件整體引入和按需引入整體引入兩個(gè)庫(kù)一樣的方法。 (近期給自己立了個(gè)小flag,讀源碼,每周至少讀1篇源碼) 下面來(lái)談?wù)刬view 和 Elemet UI 這兩個(gè)基于Vue 的UI 框架源碼的基本結(jié)構(gòu)以及區(qū)別。 一、文件結(jié)構(gòu)開(kāi)發(fā)主要放在根文件夾下的src下: 1. ivew 文件...

    hizengzeng 評(píng)論0 收藏0
  • iview 和 Elemet UI 源碼比較

    摘要:近期給自己立了個(gè)小,讀源碼,每周至少讀篇源碼下面來(lái)談?wù)労瓦@兩個(gè)基于的框架源碼的基本結(jié)構(gòu)以及區(qū)別。例如四兩個(gè)庫(kù)組件整體引入和按需引入整體引入兩個(gè)庫(kù)一樣的方法。 (近期給自己立了個(gè)小flag,讀源碼,每周至少讀1篇源碼) 下面來(lái)談?wù)刬view 和 Elemet UI 這兩個(gè)基于Vue 的UI 框架源碼的基本結(jié)構(gòu)以及區(qū)別。 一、文件結(jié)構(gòu)開(kāi)發(fā)主要放在根文件夾下的src下: 1. ivew 文件...

    haoguo 評(píng)論0 收藏0
  • 手摸手,帶你用vue擼后臺(tái) 系列三(實(shí)戰(zhàn)篇)

    摘要:社區(qū)的認(rèn)可目前已經(jīng)是相關(guān)最多的開(kāi)源項(xiàng)目了,體現(xiàn)出了社區(qū)對(duì)其的認(rèn)可。監(jiān)聽(tīng)事件手動(dòng)維護(hù)列表這樣我們就簡(jiǎn)單的完成了拖拽排序。 完整項(xiàng)目地址:vue-element-admin 系類文章一:手摸手,帶你用vue擼后臺(tái) 系列一(基礎(chǔ)篇)系類文章二:手摸手,帶你用vue擼后臺(tái) 系列二(登錄權(quán)限篇)系類文章三:手摸手,帶你用vue擼后臺(tái) 系列三(實(shí)戰(zhàn)篇)系類文章四:手摸手,帶你用vue擼后臺(tái) 系列...

    Channe 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<