摘要:今年的大會上,受到作者現場開源項目的感染,我們也在現場宣布開源這套基于開發的組件庫。一個文件夾下有所有的官方插件,直到發現他們用了一個叫的工具。那么如何寫樣式同時多帶帶發布的組件如何引用樣式文件也是我們要解決的問題。
今年的 JSConf 大會上,受到 gridcontrol 作者現場開源項目的感染,我們也在現場宣布開源這套基于 Vue 2 開發的組件庫 —— Element。上場前五分鐘才建的空倉庫,到晚上我們真正推代碼上去已經收(pian)到了 100 多 star,而且僅僅三天時間就獲得了 1k star。這個項目其實早在 Vue 2 進入 beta 時就開始開發了,一直到八月底才接近尾聲。初期也遇到一些棘手的問題,很慶幸都找到了解決方案。在這里整理一些解決方案分享給大家。
如何管理多個獨立的組件項目 -- lerna最初制定的目標是有一個主項目管理所有的組件弄成一個包,然后每一個組件都是多帶帶一個包。這樣用戶可以安裝所有組件也可以只安裝自己需要的組件。于是我們最直接的做法就是一個組件建一個項目,到后面組件越來越多管理起來也越加復雜,每一次升級主倉庫就要更新一堆依賴組件的版本號。而且開發起來也不方便。
后來看到 babel 的倉庫的目錄結構很是奇特。一個 packages 文件夾下有所有的 babel 官方插件,直到發現他們用了一個叫 lerna 的工具。可以讓你在主項目下管理多個子項目,從而解決了多個包互相依賴,且發布時需要手動維護多個包的問題。
所以我們重構了目錄結構,所有插件多帶帶一個項目放在 packages 目錄下,可多帶帶打包發布;同時最外面的 src 目錄下的入口文件引入所有組件,打包發布的主項目就是包含了所有的組件。從而就解決了多個子項目管理的問題。
element/ package.json packages/ component-a/ package.json component-b/ package.json如何解決定制多套主題的問題
組件庫一般都會自帶一套主題,也可能會有多套主題可供選擇,當然也要滿足用戶自定義的需求。所以 Vue 推薦的定義 scope 的樣式就不可行了,同時也不能把樣式寫在組件里。那么如何寫樣式同時多帶帶發布的組件如何引用樣式文件也是我們要解決的問題。
為了方便用戶覆蓋樣式,我們采用 BEM 風格來寫 CSS,這樣的好處是類名基本都是一級,少數才會有嵌套情況,這樣很容易的就可以直接覆蓋掉原有樣式。我們使用了自家開發的 postcss-salad PostCSS 插件來寫樣式。集成了多個實用的 PostCSS 插件同時也支持 BEM 風格。
并且樣式文件目錄也作為多帶帶一個子項目發布,這樣引入整個包可以包含樣式文件,多帶帶安裝的組件可以通過安裝主題包的方式引入樣式文件。
這么做的好處是方便以后擴展其他主題,或者開發者可以自己定義一套其他 CSS 預處理的版本例如 Less 或 Scss。
文檔是如何工作的 -- vue-markdown-loader當初寫 Mint UI 時就遇到了要用 Vue 寫文檔的問題:如何才能在寫 Markdown 時也能寫 Vue 組件的 Demo。雖然后來并沒有在 Mint UI 的文檔里寫 Demo。最開始在 Element 的內部版本里,找遍了各種 Vue 的 Markdown 相關插件,要么是在 template 里定義 Markdown 格式,要么就是有一個 Markdown 的組件。都不能做到純粹的寫 Markdown 文件,并且還能寫 Demo。
后來想到或許可以嘗試把 Markdown 文件轉成 Vue 組件。畢竟可以在 Markdown 里寫 HTML,那么完全可以作為 Vue 的模板。后來就有了 vue-markdown-loader,一個把 Markdown 轉成 Vue 組件的 webpack loader,搭配 vue-router 就能搭建一個可以在 Markdown 里寫 Vue 代碼的文檔網站。
如何同時打包多個組件 -- cooking由于前面的設定,最終需要每個組件都多帶帶打包一份并發布。同時每一個組件下面都會有一個對應的配置文件,傳統的用 webpack 打包雖然支持傳入數組,但是并不能傳入多個文件。但是我們有 cooking,一個基于 webpack 但是配置更簡單同時使用上也更容易的工具。打包時只需要同時傳入多個配置文件,利用 webpack 接受數組配置項的特性,就能同時進行打包。
有了這些工具,讓 Element 的開發工作變得更容易且更高效。現在 Element 已經正式開源,并且我們已經放出了文檔,同時還放出了設計資源,歡迎各位 Vue 開發者來嘗試,也歡迎來做貢獻。
相關項目鏈接:
https://github.com/ElemeFE/element
https://github.com/lerna/lerna
https://github.com/ElemeFE/postcss-salad
https://github.com/ElemeFE/mint-ui
https://github.com/QingWei-Li/vue-markdown-loader
https://github.com/ElemeFE/cooking
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/80528.html
摘要:簡潔直觀強悍的前端開發框架,讓開發更迅速簡單。是一套基于的前端框架。首個版本發布于年金秋,她區別于那些基于底層的框架,卻并非逆道而行,而是信奉返璞歸真之道。 2017-1209 ZanUI (Vue) 2017-1218 Onsen UI(Vue, React, Angular) 2017-1215 增加 Vuetify, Weex UI, Semantic UI React,ele...
摘要:簡潔直觀強悍的前端開發框架,讓開發更迅速簡單。是一套基于的前端框架。首個版本發布于年金秋,她區別于那些基于底層的框架,卻并非逆道而行,而是信奉返璞歸真之道。 2017-1209 ZanUI (Vue) 2017-1218 Onsen UI(Vue, React, Angular) 2017-1215 增加 Vuetify, Weex UI, Semantic UI React,ele...
摘要:弄了一個持續更新的筆記,可以去看看,誠意之作本來就是寫給自己看的鏈接地址此篇文章的地址的自定義滾動,我用基礎筆記的地址可以也可以。大家總會見過不少滾動條比較優雅的實現,不可否認,美是讓人愉悅的。 弄了一個持續更新的github筆記,可以去看看,誠意之作(本來就是寫給自己看的……)鏈接地址:Front-End-Basics 此篇文章的地址:Vue的自定義滾動,我用el-scrollb...
摘要:弄了一個持續更新的筆記,可以去看看,誠意之作本來就是寫給自己看的鏈接地址此篇文章的地址的自定義滾動,我用基礎筆記的地址可以也可以。大家總會見過不少滾動條比較優雅的實現,不可否認,美是讓人愉悅的。 弄了一個持續更新的github筆記,可以去看看,誠意之作(本來就是寫給自己看的……)鏈接地址:Front-End-Basics 此篇文章的地址:Vue的自定義滾動,我用el-scrollb...
閱讀 2538·2021-10-12 10:12
閱讀 1720·2019-08-30 15:52
閱讀 2454·2019-08-30 13:04
閱讀 1741·2019-08-29 18:33
閱讀 967·2019-08-29 16:28
閱讀 454·2019-08-29 12:33
閱讀 2062·2019-08-26 13:33
閱讀 2366·2019-08-26 11:36