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

前端的自動化重構

開發 前端 自動化
過去,我一直想著抽時間寫一個小的前端工具,以對代碼進行自動化的重構。

[[356196]]

過去,我一直想著抽時間寫一個小的前端工具,以對代碼進行自動化的重構。但是呢,經過我再三的考慮,我暫時取消了這個打算 —— 主要是沒時間。(PS:人生長樂,寫個 Charj) 但是呢,我打算寫一篇文章記錄一下相關的思路。

原因依據很多:

  1. 大部分國內的公司使用的都是 Vue,template、script、style 都耦合在一起;
  2. 大量的前端項目都是輕邏輯,不具有復雜的業務場景
  3. 前端系統被重寫的頻率太快了
  4. JavaSript 語法太靈活,而 TypeScript 還未普及
  5. ……

簡單來說,在缺乏復雜場景的情況下,我不太想去寫這樣的工具。

如何構建前端自動化重構工具?

在我之前寫的那篇『重構的自動化』中,介紹了如何去做這樣的工具:

  1. 構建特定語言的語法解析器。
  2. 設定代碼壞味道的內容及標準。
  3. 針對于每一項壞味道,編寫識別代碼。
  4. 編寫代碼壞味道的建議改進和實施代碼。
  5. 實現壞味道的自動化重構。

以 Vue 為例,這個過程便是:

  1. 尋找適用于 Vue 的 AST 生成工具。如 eslint-vue-parser
  2. 尋找和編寫適用于 Vue 編碼的相關規范。
  3. 對應規范尋找代碼中的問題。
  4. 針對該問題尋找改進點
  5. 實現自動化重構

讓我們來看個簡單的示例,如我們的代碼規范中,針對于組件庫強制規范了一定要寫 scoped。而我們有大量的組件都沒有相應的實踐。這個時候,就可以通過這種方式來處理。分析中代碼中不帶 scoped 的 style,然后自動添加:

  1. <style scoped> 
  2. </style> 

添加的模式其實也比較簡單:

  1. 解析后,AST 將帶有標簽等等的位置信息。
  2. 針對所有相關類型的文件進行識別,記錄所需要重構的相關信息。file、 location、 changed、 length。
  3. 反向遍歷所有的待修改處,讀取對應的文件,對應的位置,進行修改。
  4. 保存文件。
  5. 再次運行。

嗯,就是這么簡單。

配套工具

根據我先前的一些調研,我整理了一些相關的資料,歡迎大家去玩。

JavaScript

如果只是針對于簡單的 JavaScript 重構來說,我們可以考慮使用 jscodeshift 這一類的工具。jscodeshift 是一個工具包,用于在多個 JavaScript 或TypeScript 文件上運行 codemods(自動代碼修改)。

當然了,如果你不嫌麻煩的話,還可以使用類似的工具:

Source Esprima 4.0.1 UglifyJS2 Traceur Acorn 8.0.4 Shift Shift (no early errors)
jQuery.Mobile 1.4.2 149.6 ±1.8% 170.7 ±1.2% 178.2 ±6.0% 214.4 ±13.0% 429.5 ±13.5% 203.9 ±9.6%
Angular 1.2.5 125.0 ±2.8% 138.2 ±2.9% 134.5 ±2.3% 113.8 ±2.8% 251.5 ±1.3% 147.1 ±1.5%
React 0.13.3 127.2 ±1.0% 158.2 ±1.4% 160.0 ±0.8% 128.5 ±2.8% 310.8 ±2.7% 182.6 ±2.7%
Total 401.8 ms 467.0 ms 472.7 ms 456.7 ms 991.9 ms 533.5 ms

嗯,原理都是相似的。

TypeScript

官方提供了 AST 解析。

從我的之前寫的前端架構守護工具:https://github.com/phodal/dilay,你就可以看到相似的代碼。

CSS

針對于 CSS 重構來說,相似的工具有:https://github.com/csstree/csstree

不過,我們建議你們使用 Lemonj(使用 Antlr 進行語法樹解析):https://github.com/twfe/lemonj

框架特定

針對于 Angular,官方提供了 Angular Schematics,除了自動代碼修改,還可以做各種自動化升級工作。

針對于 Vue,官方也有類似的工具:https://github.com/vuejs/vue-codemod

針對于 React,官方也有工具:https://github.com/reactjs/react-codemod

結合 CLI 工具

當我們修改完代碼之后,下一步要做的事情就是修改文件,這里推薦一下: schematics-utilities,雖然是 Angular 上下游的工具,但是它不限于框架。

有了這個工具,我們就可以快速修改代碼,如:

  1. recorder = tree.beginUpdate(path); 
  2.  
  3. recorder 
  4. .remove(start, length) 
  5. .insertLeft(start, value); 
  6.  
  7. tree.commitUpdate(recorder); 

這些都大同小異,沒有什么特別之處。

總結

嗯,人生苦短,一定要花 1 小時寫個工具,解決 10 分鐘能完成的事情。

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

 

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

2022-03-30 09:43:19

jscodeshif自動化重構開發

2020-12-01 07:01:41

CSS工具重構

2021-06-28 06:32:46

Tekton Kubernetes Clone

2022-02-21 11:24:14

代碼工具開發

2013-09-03 09:58:51

Web前端

2022-09-14 10:00:12

前端自動化測試

2021-06-30 19:48:21

前端自動化測試Vue 應用

2017-12-17 21:58:18

2021-06-25 10:57:30

前端自動化測試開發

2016-09-26 16:42:19

JavaScript前端單元測試

2021-06-26 07:40:21

前端自動化測試Jest

2022-09-14 23:14:26

前端自動化測試工具

2022-02-18 13:12:49

人工智能自動化技術

2022-02-17 17:37:17

超級自動化人工智能AI

2020-04-29 11:28:54

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

2010-12-06 09:59:58

2023-05-18 14:01:00

前端自動化測試

2021-07-02 17:22:50

前端TDDBDD

2022-03-10 10:12:04

自動化腳本Bash

2017-01-16 13:38:05

前端開發自動化
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一道本视频 | 中文字幕高清av | 91色啪 | 久久精品色欧美aⅴ一区二区 | 成人免费小视频 | 欧美成人a∨高清免费观看 91伊人 | 免费一区二区 | 精品久久久久久久久久久 | 四虎永久影院 | 一区二区在线 | 影视先锋av资源噜噜 | 亚洲精品www | 日韩免费视频 | 国产亚洲成av人在线观看导航 | 日韩欧美三区 | 国产欧美精品一区 | 黄色成人免费在线观看 | 成人av一区二区三区 | 伊人春色在线观看 | 亚洲福利电影网 | 91免费福利视频 | 一区二区三区欧美 | 国产精品亚洲一区二区三区在线观看 | 亚洲欧洲成人av每日更新 | 羞羞视频在线网站观看 | 狠狠草视频 | 日韩国产中文字幕 | 午夜在线观看视频 | 成人欧美一区二区 | 亚洲午夜av久久乱码 | 亚洲经典一区 | 精品在线免费看 | 日韩精品一区二区三区在线观看 | 久久性色 | 中文字幕亚洲一区二区va在线 | 精品国产18久久久久久二百 | xxx视频| 91社影院在线观看 | 日韩黄a | 亚洲精品一区二区三区丝袜 | 深夜爽视频 |