如何從零開始,成為element-plus的contributor

序言

提到element-ui,我想很多前端er應該都不陌生,而element-ui也是我第二個使用的前端UI庫,第一個是bootstrap(笑)。我是在去年初學vue的時候開始接觸elemment-ui的,到現在也快一年了,中間經歷了vue3的誕生,想想前端技術發展的還真快(笑)。在vue3發布后,社區許多前端er還在擔心element-ui還維護嗎,這不,全新的element-plus就來了(你從未體驗過的船新版本)。(笑)

我是在上個月前開始關注element-plus得,那時它還只有1.9k star。現在已經漲到了5.6k。

那時我想著給一些開源項目做一下貢獻,就開始了我的第一個PR,而element-plus恰好是我的選擇,不知不覺到現在我已經給element-plus提交了6個PR,其中有2個水PR(笑)。中間經歷了花費幾個小時來看懂一部分源碼,打斷點調試好幾個小時最后可能只改動了2行代碼等等,不得不說這種公司大型項目跟自己在學校的工作室寫的過家家代碼根本就不是一回事,當然我也從中有了許多收獲。下面開始正題。

如何提PR

1、fork element-plus 到自己倉庫。

2、git clone https://github.com/{you github name}/element-plus.git

3、npm run bootstrap下載相關依賴包。

4、這時就可以開始你的改代碼之旅了。而且element-plus項目非常貼心地提供了本地Debug的途徑,你可以在website目錄下的子目錄play中新建一個index.vue文件,在這里你可以隨意使用各種組件且不必import {component},然后運行npm run website-dev:play就可以在本地查看了,此外運行npm run website-dev也可以在本地查看element-plus文檔的官網。最好再將element倉庫也設置為遠程倉庫。git remote add upstream https://github.com/element-plus/element-plus.git dev。這樣便于以后更新本地代碼。

5、當你修改完代碼后,可以先執行npm run lint-fix進行eslint檢查和修改。

6、接著執行git add .儲存。

7、執行npm run cz。執行這個命令可以幫助我們生成規范的commit信息。跟著指令一步一步來即可。

先選擇commit的類型。

接著輸入是哪個組件或者文件的修改。

輸入commit簡短描述

輸入commit長敘述

選擇是否是破壞性改變。

是否與某個issue相關聯

輸入相關聯issue, fix是修復, re是引用

8、最后推送到自己的倉庫,然后再pull request就可以了,提交PR后,項目的CI還會進行代碼檢查,不過如果做好上述步驟,基本都會通過的。接下來就等element-plus的成員來review你的代碼了,通過就會被合并了。

記錄我給element-plus的2次pull request

一次我看到這樣一個issue

其中提到select組件點2次下拉框應收回,但事實卻并沒有。經過漫長的debug,我發現這個Bug與element-plus內部的一個指令v-click-outside有關。它加在了select組件中的一個子組件上,但我發現應加在根div上,故修改如下。

這樣就解決了這個Bug。

之后,我又看到了這樣一個issue。色彩選取組件無法關閉在點擊2次時。

仔細想想,這個Bug是不是和上面提到的很相似?我的解決方法是加了一個行內塊狀的根div,并將v-click-outside指令改到它的身上,從而解決了Bug。

最后

總的來說,自己給element-plus提的PR大多是修復Bug的,但還沒有過feature PR,其實是自己太菜了(笑),還是要鞭策自己繼續努力吧。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/251444.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/251444.shtml
英文地址,請注明出處:http://en.pswp.cn/news/251444.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

將Vue+Nodejs項目部署到阿里云服務器

上傳文件至云服務器 一、打包文件 在項目根目錄下運行 npm run build等待命令運行結束后,會發現目錄下多了 dist 文件夾,這個文件夾就是我們等下要放到服務器中的。 二、文件傳輸 打開 Xftp與實例建立連接云服務器Apache默認的根目錄是/var/www/htm…

javascript --- 函數的優化(尾調用優化)

從一個熟悉的Fibonacci數列的實現開始: function Fibonacci (n) {if ( n < 1) { return 1};return Fibonacci(n -1) Fibonacci(n-2); }以上代碼很簡單… 但執行以下代碼 console.log(Fibonacci(100));會發現編譯工具,卡住不動. 原因在于:遞歸調用(函數調用自身),每次都會…

第5課 - 線性表的本質

第5課 - 線性表的本質 數據結構是為了解決生活中的實際問題而存在的&#xff0c;那生活中與線性表相對應的例子有什么呢&#xff1f; 幼兒園中就有一個例子&#xff0c;在老師安排小朋友活動時&#xff0c;會將小朋友組織成下面的站隊形式&#xff0c;這個就是線性表。 1. 線性…

Django--網頁管理實例解析

此篇為代碼流程的注釋以及自己寫的小項目的思路&#xff1a; 首先是項目的路由配置&#xff1a; 1 urlpatterns [2 # url(r^admin/, admin.site.urls),3 url(r^yemian/,yemian),4 url(r^zuoye/,zuoye),5 url(r^class/,views.class_list),6 url(r^class_ad…

阿里云ecs實例中創建數據庫

阿里云ecs實例中創建數據庫安裝mysql創建數據庫1.登錄2.新建數據庫3.執行.sql文件4.查詢表&#xff0c;驗證是否創建成功4.退出數據庫安裝mysql 參考https://blog.csdn.net/qq_36350532/article/details/79496049 創建數據庫 1.登錄 mysql -u root -p&#xff08;這里寫密碼…

javascript --- 尾遞歸優化的實現

考慮一個正常的遞歸函數 function sum(x, y) {if (y > 0) {return sum (x 1, y - 1);} else {return x;} } sum(1, 100000000);超出調用棧的最大次數… 下面使用尾遞歸優化實現: function tco(f) {var value ;var active false;var accumulated [];return function acc…

《對不隊》團隊項目用戶驗收評審

任務1&#xff1a;團隊作業Beta沖刺 Beta沖刺第一天&#xff1a;https://www.cnblogs.com/bingoF6/p/9221744.htmlBeta沖刺第二天&#xff1a;https://www.cnblogs.com/bingoF6/p/9226305.htmlBeta沖刺第三天&#xff1a;https://www.cnblogs.com/bingoF6/p/9230815.htmlBeta沖…

部署項目的問題(一)—— vue工程打包上線樣式錯亂問題

1、 打開index.html一片空白 參考&#xff1a;鏈接: link. 修改build對象里的assetsPublicPath為’./’ assetsPublicPath: ./2、ElementUI樣式丟失 參考&#xff1a;鏈接: link. 這里嘗試完前三種&#xff1a; 1.main.js樣式引入順序問題 調整了import的順序&#xff08;…

遲遲發布的軟工實踐兩月感想

第七周&#xff0c;第八周了。 寫幾點反省。 嚴謹。工作的時候&#xff0c;說話行文風格要注意&#xff0c;因為這影響溝通的質量&#xff0c;影響別人對你的評價。會間接影響對方的響應&#xff0c;影響合作。學會主動承擔責任&#xff0c;做受關注的那個人。主動鍛煉自己。開…

構建SpringBoot第一個Demo

使用官方地址生成項目 https://start.spring.io Generate&#xff1a;可以選擇Maven或者Gradle構建項目 語言&#xff1a;我想一般都是Java 接下來選擇SpringBoot的版本&#xff0c;目前比較穩定的1.5.10 GroupID&#xff1a;自定義 Artifact&#xff1a;自定義 Dependencies&…

部署項目的問題(二)—— 阿里云服務器 ECS升級node版本

在運行服務端代碼時報錯&#xff0c;當時報錯的代碼沒copy下來&#xff0c;大概就是如下形式 mbp:hybrid-statistic wfp$ node app.js /Users/wfp/Work/hybrid-statistic/app.js:28 async function responseTime(ctx, next) {^^^^^^^^ SyntaxError: Unexpected token function…

javascript --- Object.assign()淺復制解決方法

Object.assign()是淺復制(即:只復制對象得引用而,而不是新實例).它無法正確復制get屬性和set屬性. 看下面得例子: // 定義一個source對象,含set方法 const source {set foo(value) {console.log(value);} };// 使用Object.assign進行賦值 const target1 {}; Object.assign(t…

微信小程序與Java后臺的通信

一、寫在前面 最近接觸了小程序的開發&#xff0c;后端選擇Java&#xff0c;因為小程序的代碼運行在騰訊的服務器上&#xff0c;而我們自己編寫的Java代碼運行在我們自己部署的服務器上&#xff0c;所以一開始不是很明白小程序如何與后臺進行通信的&#xff0c;然后查找資料發現…

面向對象初識④

抽象類與接口類 接口類 繼承有兩種用途&#xff1a; 一&#xff1a;繼承基類的方法&#xff0c;并且做出自己的改變或者擴展&#xff08;代碼重用&#xff09; 二&#xff1a;聲明某個子類兼容于某基類&#xff0c;定義一個接口類Interface&#xff0c;接口類中定義了一些接口…

部署項目的問題(三)—— node啟動服務時listen監聽的端口被占用

Error: listen EADDRINUSE :::8888表示的就是listen監聽的端口被占用 查詢什么進程占用了8888端口 sudo fuser -n tcp 8888 &#xff08;指令一&#xff09; 或者 netstat -tln | grep 8888 &#xff08;指令二&#xff09;反復執行指令一&#xff0c;總得到不同結果&#x…

es6 --- 內置的Symbol值

Symbol.hasInstance // Symbol.hasInstance class MyClass {[Symbol.hasInstance] (foo) {return foo instanceof Array;} } [1, 2, 3] instanceof new MyClass() // true// symbol.hasInstance:會在[1, 2, 3] instanceof 時 自動調用 [Symbol.hasInstance] (foo) 方法... //…

對象的克隆

對象的克隆 1、克隆即復制的意思&#xff0c;對象的克隆&#xff0c;意味著生成一個對象&#xff0c;這個對象和某個對象的屬性和行為是一致的&#xff0c;但是這個對象和源對象是兩個不同的對象。實現對象的克隆&#xff0c;方法是實現Cloneable接口&#xff0c;否則會報異常C…

15 調試

1. pdb pdb是基于命令行的調試工具&#xff0c;非常類似gnu的gdb&#xff08;調試c/c&#xff09;。 def getAverage(a,b):result abprint("result is %s"%result)return resulta 10 b 20 c ab ret getAverage(a,b) print(ret) 2.執行時調試 程序啟動&#xff0…

html5播放視頻只有聲音不出現畫面?

一開始網上大神們都是要把MP4的編碼格式轉換成AVC&#xff08;H264&#xff09;&#xff0c;然后趕緊用格式工廠把它給換了&#xff0c;結果&#xff01;&#xff01; 沒用&#xff01;&#xff01;還是黑屏&#xff1f;&#xff1f;&#xff1f;咋回事啊&#xff0c;然后自己又…

vue項目代碼改進(一)login組件

Login登錄組件 1. 新增登錄頭像&#xff08;css樣式回顧&#xff09; 1&#xff09;div.avatar 2&#xff09;子絕父相定位&#xff0c;left…top… 3&#xff09;border 4&#xff09;placeholder 5&#xff09;box-shadow box-shadow: offset-x offset-y blur spread color …