摘要:接下來來看一下是如何編寫一個組件的,在看源碼之前,首先還是要對他的組件的大致功能有一個了解,這樣我們在看源碼的時候才會知道這一段大概實現了什么功能。最后我實現的功能文檔以及最終的一個樣例
在你實現一個組件過程中,一定要注意一下幾點
將代碼模塊化并且分離。如果你將大量的邏輯或者是代碼都放在鉤子函數中(比如mounted),那么寫出來的組件代碼將非常丑陋,這樣子寫出的代碼也往往難以維護。
第二就是要注意可擴展性。因為定制一個基礎組件,也許當你日后還想對它的功能進行擴展的話,那么一定要注意自己代碼的編寫結構。
接下來來看一下element ui是如何編寫一個table組件的,在看源碼之前,首先還是要對他的table組件的大致功能有一個了解,這樣我們在看源碼的時候才會知道這一段大概實現了什么功能。
點開table的src目錄下,有這么幾個文件
dropdown.js
filter-panel.vue(實現表格勾選的組件)
table-body.js (實現表格body的組件)
table-column.js (實現表中中每一列的組件)
table-footer.js (定義表格尾部的組件,會有一些合計的功能)
table-header.js(定義表格thead的文件)
table-layout.js (定義表格布局的文件)
table-store.js(定義事件的方法集中在這里)
table.vue(最終將上述組件整合后的一個最終table組件)
util.js(定義了一些工具函數)
對于這個結構也就是像一開始提到的那樣,將代碼盡量拆分,這樣組織下來結構清晰。分析的時候我將舉例每一種情況的代表,類似的照著實現就可以了。
首先是事件的實現
以row-click為例,我們使用這個事件的方式是@row-click=“dosomething”,那組件內部如何觸發這個事件呢,最簡單的方法就是在每一次tr循環的時候都去綁定上一個@click事件就好,在這個事件里面去emit(‘row-click’)事件就好,可是這就是會有一個問題,事件一多,代碼都集中在methods中,會寫出非常長的代碼,這個時候就需要分離,我們新建一個store.js,用來管理各種事件。大致實現如下:
const TableStore = function (table,initialSatate) { this.table = table this.states = {} } TableStore.prototype.mutations = { handleRowClick () { this.table.emit("row-click") } } Table.prototype.commit = function (name,..agrs){ mutations[name].apply(name,args) }
我們在表格table創建一開始,在data (){}中就會創建一個新的tableStore對象,我們在每一行點擊的時候只用this.store.commit("handleRowClick");基于這個流程,如果以后還需要繼續添加事件,你就可以在mutations里面去定義。
layout.js也是一樣的道理,這里我只是對表格的高度去進行了設定,對于一個vue對象來說,不能用dom思路去實現它的高度,我是將vue對象打印出來,在一步一步尋找那個style屬性
TableColumn的實現
其實對于一個表格來說,他的表頭將會很重要。在螞蟻金服的那個antd組件庫中,他們對于表頭的定義是這樣的,你需要傳入一個columns(props),里面將你定義的每一列信息寫進去,而vue在實現的過程中,是將作為
組件children元素,在組件里再去定義每一列的屬性,基于這兩種實現方式的不同,我覺得很大程度上是因為vue中有一個標簽(也可能是別的原因),但是又有一個問題,就是在table-header/table-body/table-column中,他們都是用的render方法去渲染組件,我在參考他們官方編寫的過程中,用到了jsx語法的模式,不是很理解為什么又采用這種方式去編寫組件。
最后我實現的table功能文檔
以及最終的一個樣例demo
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/82985.html
摘要:本文章從如下圖所示的最基本的入手,分析組件源代碼。本人已經對組件原來的源碼進行削減,源碼點擊這里下載。還有兩個重要的函數與。在組件的階段會調用更新,從而觸發重新渲染。例如當組件加載后發送請求,待請求響應賦值,重新渲染。 本文章從如下圖所示的最基本的table入手,分析table組件源代碼。本人已經對table組件原來的源碼進行削減,源碼點擊這里下載。本文只對重要的代碼片段進行講解,推薦...
摘要:社區的認可目前已經是相關最多的開源項目了,體現出了社區對其的認可。監聽事件手動維護列表這樣我們就簡單的完成了拖拽排序。 完整項目地址:vue-element-admin 系類文章一:手摸手,帶你用vue擼后臺 系列一(基礎篇)系類文章二:手摸手,帶你用vue擼后臺 系列二(登錄權限篇)系類文章三:手摸手,帶你用vue擼后臺 系列三(實戰篇)系類文章四:手摸手,帶你用vue擼后臺 系列...
摘要:社區的認可目前已經是相關最多的開源項目了,體現出了社區對其的認可。監聽事件手動維護列表這樣我們就簡單的完成了拖拽排序。 完整項目地址:vue-element-admin 系類文章一:手摸手,帶你用vue擼后臺 系列一(基礎篇)系類文章二:手摸手,帶你用vue擼后臺 系列二(登錄權限篇)系類文章三:手摸手,帶你用vue擼后臺 系列三(實戰篇)系類文章四:手摸手,帶你用vue擼后臺 系列...
摘要:下面一步步拆解上述流程。切換至分支檢測本地和暫存區是否還有未提交的文件檢測本地分支是否有誤檢測本地分支是否落后遠程分支發布發布檢測到在分支上沒有沖突后,立即執行。 背景 最近一直在著手做一個與業務強相關的組件庫,一直在思考要從哪里下手,怎么來設計這個組件庫,因為業務上一直在使用ElementUI(以下簡稱Element),于是想參考了一下Element組件庫的設計,看看Element構...
摘要:源碼真的這么可怕嗎從以上的事例中可以看出,其實并沒有。對于源碼的恐懼,讓我們漸漸思維固化,自己告訴自己不要去碰源碼,時間長了就遺忘了還有這樣一條路可走。 一個小需求 事情的起因,是昨天有一個新的需求被提出。 需求是要實現,讓我們自己定制的彈出層,具備按下 ESC 也能退出的功能。我把任務交給了同組的小伙伴S去實現。(這個項目用到了vue技術棧,以及餓了么的UI框架。) 我開完會回來,發...
閱讀 1272·2021-09-23 11:51
閱讀 1391·2021-09-04 16:45
閱讀 632·2019-08-30 15:54
閱讀 2083·2019-08-30 15:52
閱讀 1602·2019-08-30 11:17
閱讀 3106·2019-08-29 13:59
閱讀 2020·2019-08-28 18:09
閱讀 387·2019-08-26 12:15