成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Lemonj:類 CSS 的自動化重構工具

開發 開發工具 自動化
開發人員對于 CSS 及其 CSS 預處理器的使用是一個很有意思的問題 —— 過去,我一直在吐槽這些想寫好 CSS 的人,卻是一點兒也不想高認真學習 CSS。

[[354884]]

最近,在幫助一家大型公司的大型前端項目設計和構建前端體系,期間和我同事 @Liuuy 討論起了 CSS 的架構和設計問題。開發人員對于 CSS 及其 CSS 預處理器的使用是一個很有意思的問題 —— 過去,我一直在吐槽這些想寫好 CSS 的人,卻是一點兒也不想高認真學習 CSS。

于是,在我們的討論之下,我借助了在編寫 Coca 的經驗,設計和驗證了自動化重構的可能性。由我的同事完成了 TypeScript 的 CSS 自動化重構工具:Lemonj —— 名字是我取的 。

Lemonj

GitHub:https://github.com/twfe/lemonj

Lemonj 是一個面向 CSS/LESS/SCSS 的分析、壞味道檢查和自動化重構工具。

從架構上來說,它就是通過 Antlr + Antlr4TS 生成對應的解析器生成器,而后根據需要處理所需的字段對相應的內容進行標記。隨后,根據我們的需要和設計,通過 AST 中的位置信息,修改對應的內容值。

如 importants 數量分析中的代碼:

  1. if (Checker.hasImportant(propertyValue)) { 
  2. if (!this.metadata.importants) { 
  3. this.metadata.importants = []; 
  4.  
  5. this.metadata.importants.push({ 
  6. type: '!important'
  7. file: this.metadata.filePath, 
  8. line: ctx._start.line, 
  9. }); 

它便是獲取 CSS 屬性中的內容,檢查是否有 !important,然后記錄一下位置信息。

與 CSS 轉換器的不同之處

或許你也用過各類的 CSS/LESS/SAAS 轉換工具,所以會好奇它們與 Lemonj 的相似與不同之處在哪里。

CSS 轉 CSS 預處理器轉換工具。它們都是一鍵式的上傳一個類 CSS 文件,從中提取語法樹,轉換到新的形式上。而要實現不同預處理器的轉換,你可能還需要多個轉換工具。而且它們只能在一個文件上修改,而你的代碼是分散在代碼庫中。

Lemonj 自動化重構 CSS 工具。也是分析語法樹,從中提取文件的信息,但不能直接轉換到新的形式上。而是要分析出代碼中的問題,結合 AST 中獲取到的位置信息,再回到指定的文件中對它們進行自動化修改。

你可以認為一個是在現有的代碼基本上自動修改,一個是則是普通的轉換工具 —— 畢竟根據位置修改是一個累人的工作。

使用 Lemonj 進行 CSS 自動化重構

1.先安裝 Lemonj,即: npm install lemonj -g 又或者是: yarn global add lemonj

2.使用 Lemonj 分析下代碼: lemonj analysis _fixtures,這里的 _fixtures 是個目錄。

過程中,會生成對應的壞味道數據:

  1. Code Smell: { 
  2. colors: 24, 
  3. importants: 4, 
  4. issues: 8, 
  5. mediaQueries: 1, 
  6. absolute: 0, 
  7. oddWidth: 1 

因為壞味道功能太普通了,所以我們暫時沒有增強,并非我們的核心競爭力所在。除此,在執行 anlaysis 的時候,還會生成一些額外的信息,比如顏色的 mapping 文件:

  1. // _fixtures/less/color/border.less 
  2. @color1: #ddd; 
  3. // _fixtures/less/color/border.less 
  4. @color2: green; 
  5. // _fixtures/less/color/rgba.less 
  6. @color3: rgba(255, 0, 0, 0.3); 
  7. // _fixtures/less/color/sample.less 
  8. @color4: #ff7f50; 
  9. // _fixtures/less/color/sample.less 
  10. // _fixtures/less/color/sample2.less 
  11. @color5: #800080; 
  12. // _fixtures/less/color/sample.less 

這里的顏色只是暫時的命名,需要根據具體的需要進行調整,如按設計系統的思想,將 color_1 改成 @primary_color。

3.執行 lemonj refactor _fixtures 對代碼進行自動化重構。就能將上一步中的代碼,進一步地修改到所有的代碼文件中。

嗯,重構就是如此的簡單。

其它

Charj 的功能在完善中,歡迎大家看看你們有哪些場景適合自動化重構。

最后,記得我們的 GitHub:https://github.com/twfe/lemonj

冰河  本文轉載自微信公眾號「phodal」,可以通過以下二維碼關注。轉載本文請聯系phodal公眾號。

 

責任編輯:武曉燕 來源: phodal
相關推薦

2020-12-08 06:20:49

前端重構Vue

2022-02-21 11:24:14

代碼工具開發

2022-03-30 09:43:19

jscodeshif自動化重構開發

2021-06-28 06:32:46

Tekton Kubernetes Clone

2013-07-02 10:45:38

2016-12-05 15:48:37

2017-12-17 21:58:18

2014-11-12 09:24:00

2012-03-15 10:32:05

Windows系統網絡故障

2014-09-22 11:24:18

運維

2012-12-24 22:54:31

2011-11-18 09:11:21

Web

2022-02-18 13:12:49

人工智能自動化技術

2016-04-12 10:18:19

代碼審計自動化代碼審計工具

2022-02-17 17:37:17

超級自動化人工智能AI

2020-04-29 11:28:54

智能自動化機器人流程自動化AI

2010-12-06 09:59:58

2015-10-09 13:14:10

clip自動化運維工具

2021-09-30 09:00:00

漏洞安全工具

2011-05-30 17:50:23

分布式測試
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 影视先锋av资源噜噜 | 一区二区精品 | 一级毛片网 | 亚洲一区二区久久 | 亚洲精选一区 | 久久九七| 成人影院在线 | 一区二区三区视频在线 | 91偷拍精品一区二区三区 | 久草福利| 婷婷在线免费 | 亚洲 欧美 另类 综合 偷拍 | 天天爽夜夜操 | 国产亚洲欧美在线视频 | 亚洲国产精品久久久 | 国产激情精品一区二区三区 | 天天视频成人 | 欧美亚洲国产一区二区三区 | 免费在线观看一区二区三区 | 欧美日韩高清在线一区 | 黑人精品 | 国产精品免费在线 | 精品国产一区二区三区久久久久久 | 国产小视频在线观看 | 99在线资源| 欧美片网站免费 | 久久久久久91 | 成人精品国产免费网站 | 国产在线a| 人人做人人澡人人爽欧美 | 日韩在线一区二区三区 | 91精品国产色综合久久 | 中文字幕在线第一页 | 国产午夜精品一区二区三区在线观看 | 久久综合久 | 日韩国产在线 | 国产69久久精品成人看动漫 | 久久久久久久久久久久久9999 | 国产精品久久久久久一区二区三区 | 色黄网站| 99国内精品|