摘要:本文章從如下圖所示的最基本的入手,分析組件源代碼。本人已經(jīng)對組件原來的源碼進(jìn)行削減,源碼點(diǎn)擊這里下載。還有兩個重要的函數(shù)與。在組件的階段會調(diào)用更新,從而觸發(fā)重新渲染。例如當(dāng)組件加載后發(fā)送請求,待請求響應(yīng)賦值,重新渲染。
本文章從如下圖所示的最基本的table入手,分析table組件源代碼。本人已經(jīng)對table組件原來的源碼進(jìn)行削減,源碼點(diǎn)擊這里下載。本文只對重要的代碼片段進(jìn)行講解,推薦下載代碼把項(xiàng)目運(yùn)行起來,跟著文章的思路閱讀。
思路table、table-header、table-body、table-column之間通過table-store進(jìn)行狀態(tài)管理。table-header、table-body對table-store數(shù)據(jù)進(jìn)行監(jiān)聽,每當(dāng)table改變table-store數(shù)據(jù)時觸發(fā)table-header、table-body重新渲染。
table-column為列數(shù)據(jù)column綁定相應(yīng)的renderCell函數(shù),供table-body渲染時使用。table-column這個組件自身不做任何渲染。所以會看到模板將其隱藏。還有就是table-header、table-body通過render函數(shù)進(jìn)行渲染。
初始化順序 table
初始化store
data() { const store = new TableStore(this); return { store, }; }
將store共享給table-header、table-body
將數(shù)據(jù)存儲到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); // //{{row.frequentlyUsed | formatBoolean}} // } 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有兩個很重要的屬性_columns、data,_columns保存列的相關(guān)信息,data則保存開發(fā)者傳入的表格數(shù)據(jù)。還有兩個重要的函數(shù)insertColumn與updateColumns。
insertColumn為_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 對_columns進(jìn)行過濾得到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ù) }
這兩個組件的工作原理是監(jiān)聽columns數(shù)據(jù)變化以觸發(fā)render渲染。在table組件的mounted階段會調(diào)用 updateColumns 更新 columns,從而觸發(fā) table-header、table-body 重新渲染。
另外table-body還會監(jiān)聽data變化,觸發(fā)render。例如當(dāng)組件加載后發(fā)送請求,待請求響應(yīng)賦值data,重新渲染table-body。
computed: { data() { // table.vue watch.data 中 調(diào)用 setData 在store 中存儲 data return this.store.states.data; }, },參考
Element UI table官方文檔
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://www.ezyhdfw.cn/yun/108111.html
摘要:接下來來看一下是如何編寫一個組件的,在看源碼之前,首先還是要對他的組件的大致功能有一個了解,這樣我們在看源碼的時候才會知道這一段大概實(shí)現(xiàn)了什么功能。最后我實(shí)現(xiàn)的功能文檔以及最終的一個樣例 在你實(shí)現(xiàn)一個組件過程中,一定要注意一下幾點(diǎn) 將代碼模塊化并且分離。如果你將大量的邏輯或者是代碼都放在鉤子函數(shù)中(比如mounted),那么寫出來的組件代碼將非常丑陋,這樣子寫出的代碼也往往難以維護(hù)。...
摘要:近期給自己立了個小,讀源碼,每周至少讀篇源碼下面來談?wù)労瓦@兩個基于的框架源碼的基本結(jié)構(gòu)以及區(qū)別。例如四兩個庫組件整體引入和按需引入整體引入兩個庫一樣的方法。 (近期給自己立了個小flag,讀源碼,每周至少讀1篇源碼) 下面來談?wù)刬view 和 Elemet UI 這兩個基于Vue 的UI 框架源碼的基本結(jié)構(gòu)以及區(qū)別。 一、文件結(jié)構(gòu)開發(fā)主要放在根文件夾下的src下: 1. ivew 文件...
摘要:近期給自己立了個小,讀源碼,每周至少讀篇源碼下面來談?wù)労瓦@兩個基于的框架源碼的基本結(jié)構(gòu)以及區(qū)別。例如四兩個庫組件整體引入和按需引入整體引入兩個庫一樣的方法。 (近期給自己立了個小flag,讀源碼,每周至少讀1篇源碼) 下面來談?wù)刬view 和 Elemet UI 這兩個基于Vue 的UI 框架源碼的基本結(jié)構(gòu)以及區(qū)別。 一、文件結(jié)構(gòu)開發(fā)主要放在根文件夾下的src下: 1. ivew 文件...
摘要:社區(qū)的認(rèn)可目前已經(jīng)是相關(guān)最多的開源項(xiàng)目了,體現(xiàn)出了社區(qū)對其的認(rèn)可。監(jiān)聽事件手動維護(hù)列表這樣我們就簡單的完成了拖拽排序。 完整項(xiàng)目地址:vue-element-admin 系類文章一:手摸手,帶你用vue擼后臺 系列一(基礎(chǔ)篇)系類文章二:手摸手,帶你用vue擼后臺 系列二(登錄權(quán)限篇)系類文章三:手摸手,帶你用vue擼后臺 系列三(實(shí)戰(zhàn)篇)系類文章四:手摸手,帶你用vue擼后臺 系列...
閱讀 3086·2023-04-25 18:06
閱讀 3437·2021-11-22 09:34
閱讀 2941·2021-08-12 13:30
閱讀 2109·2019-08-30 15:44
閱讀 1734·2019-08-30 13:09
閱讀 1690·2019-08-30 12:45
閱讀 1775·2019-08-29 11:13
閱讀 3663·2019-08-28 17:51