vscode 插件可視化制作和管理腳手架及原理解析

提到腳手架,大家想到的可能就是各種 xxx-cli蛋辈,本文介紹的是另一種方式:以 vscode 插件的形式實現(xiàn)瑟慈,提供 web 可視化操作,如下圖:

下面介紹如何安裝使用仔雷,以及實現(xiàn)原理蹂析。

安裝使用

vscode 安裝 lowcode 插件,此插件是一個效率工具碟婆,腳手架只是其中一個功能电抚,更多功能可以查看文檔,這集只講腳手架相關(guān)的竖共。

插件安裝之后蝙叛,打開腳手架界面,步驟如下圖:

可以直接使用分享的腳手架公给,勾選選項后直接創(chuàng)建即可:

制作腳手架

在模板項目根目錄下創(chuàng)建 lowcode.scaffold.config.json 文件借帘,將需要做內(nèi)容動態(tài)替換的文件加上 .ejs 后綴。

ejs 語法

配置

一個完整 lowcode.scaffold.config.json 配置:

{
    "formSchema": {
        "schema": {
            "type": "object",
            "ui:displayType": "row",
            "ui:showDescIcon": true,
            "properties": {
                "port": {
                    "title": "監(jiān)聽端口",
                    "type": "string",
                    "props": {},
                    "default": "3000"
                },
                "https": {
                    "title": "https",
                    "type": "boolean",
                    "ui:widget": "switch"
                },
                "lint": {
                    "title": "eslint + prettier",
                    "type": "boolean",
                    "ui:widget": "switch",
                    "default": true
                },
                "noREADME": {
                    "title": "移除README文件",
                    "type": "boolean",
                    "ui:widget": "switch",
                    "ui:width": "100%",
                    "ui:labelWidth": 0,
                    "ui:hidden": "{{rootValue.emptyREADME === true}}",
                    "default": false
                },
                "emptyREADME": {
                    "title": "空README文件",
                    "type": "boolean",
                    "ui:widget": "switch",
                    "ui:hidden": "{{rootValue.noREADME === true}}"
                }
            },
            "labelWidth": 120,
            "displayType": "row"
        },
        "formData": {
            "port": 3000,
            "https": false,
            "lint": true,
            "noREADME": false,
            "emptyREADME": false
        }
    },
    "excludeCompile": ["codeTemplate/", "materials/"],
    "conditionFiles": {
        "noREADME": {
            "value": true,
            "exclude": ["README.md.ejs"]
        },
        "lint": {
            "value": false,
            "exclude": [".eslintrc.js", ".prettierrc.js"]
        }
    }
}

formSchema

formSchema.schemax-render 表單設(shè)計器 導(dǎo)出的的 schema淌铐,會根據(jù) schema 構(gòu)建出表單界面肺然,formSchema.formData 為表單默認數(shù)據(jù)

創(chuàng)建項目的時候會將表單數(shù)據(jù)傳入 ejs 模板中進行編譯。

excludeCompile:配置不需要經(jīng)過 ejs 編譯的文件夾或文件腿准。

conditionFiles:根據(jù)表單項的值际起,在創(chuàng)建項目的時候?qū)⒛承┪募A或文件刪除,比如:

"conditionFiles": {
    "noREADME": {
        "value": true,
        "exclude": ["README.md.ejs"]
    },
    "lint": {
        "value": false,
        "exclude": [".eslintrc.js", ".prettierrc.js"]
    }
}

當(dāng) lint 這個表單項的值為 false 的時候,配置的文件夾或文件 ".eslintrc.js"街望,".prettierrc.js"校翔,將會在創(chuàng)建的項目中排除掉。

本地調(diào)試腳手架

1648608248392.png

參考模板

https://github.com/lowcode-scaffold/lowcode-mock

發(fā)布腳手架

將腳手架提交到 git 倉庫灾前,注意開放項目的公開訪問權(quán)限防症。

使用腳手架

直接使用 git 倉庫地址

注意使用 clone 地址,支持指定分支豫柬,比如 -b master https://github.com/lowcode-scaffold/lowcode-mock.git告希,內(nèi)部私有倉庫也可以使用

分享到模板列表中快速創(chuàng)建

修改 倉庫index.json 內(nèi)容,提交 pr烧给。

實現(xiàn)原理

  1. 打開 webview 的時候從 cdn 拉取記錄了腳手架列表的 json 文件燕偶,渲染列表視圖。
  2. 點擊某個腳手架础嫡,將腳手架的 git 倉庫地址傳到插件后臺指么,插件后臺根據(jù) git 地址下載模版到臨時工作目錄,并且讀取 lowcode.scaffold.config.json 文件中的 formSchema 返回給 webview榴鼎。
export const downloadScaffoldFromGit = (remote: string) => {
  fs.removeSync(tempDir.scaffold);
  execa.sync('git', ['clone', ...remote.split(' '), tempDir.scaffold]);
  fs.removeSync(path.join(tempDir.scaffold, '.git'));
  if (
    fs.existsSync(path.join(tempDir.scaffold, 'lowcode.scaffold.config.json'))
  ) {
    return fs.readJSONSync(
      path.join(tempDir.scaffold, 'lowcode.scaffold.config.json'),
    );
  }
  return {};
};
  1. webview 拿到 formSchema 后彈框渲染動態(tài)表單伯诬,點提交后將動態(tài)表單數(shù)據(jù)以及生成目錄等信息傳給插件后臺。
  2. 插件后臺拿到表單數(shù)據(jù)后巫财,到臨時目錄中根據(jù) conditionFiles 配置刪除掉不需要的文件盗似。然后根據(jù)表單數(shù)據(jù)編譯所有 ejs 文件,最后將所有文件拷貝到生成目錄平项。
export const compileScaffold = async (model: any, createDir: string) => {
  if (
    fs.existsSync(path.join(tempDir.scaffold, 'lowcode.scaffold.config.json'))
  ) {
    const config = fs.readJSONSync(
      path.join(tempDir.scaffold, 'lowcode.scaffold.config.json'),
    );
    const excludeCompile: string[] = config.excludeCompile || [];
    if (config.conditionFiles) {
      Object.keys(model).map((key) => {
        if (
          config.conditionFiles[key] &&
          config.conditionFiles[key].value === model[key] &&
          Array.isArray(config.conditionFiles[key].exclude)
        ) {
          config.conditionFiles[key].exclude.map((exclude: string) => {
            fs.removeSync(path.join(tempDir.scaffold, exclude));
          });
        }
      });
    }
    await renderEjsTemplates(model, tempDir.scaffold, excludeCompile);
    fs.removeSync(path.join(tempDir.scaffold, 'lowcode.scaffold.config.json'));
  }
  fs.copySync(tempDir.scaffold, createDir);
};

本地調(diào)試時赫舒,就是在步驟 2 中將選擇的文件夾內(nèi)容或者當(dāng)前 vscode 打開的項目內(nèi)容拷貝到臨時工作目錄。

下集再說插件其他功能闽瓢,插件源碼:https://github.com/lowcoding/lowcode-vscode

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末接癌,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子扣讼,更是在濱河造成了極大的恐慌缺猛,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件椭符,死亡現(xiàn)場離奇詭異荔燎,居然都是意外死亡,警方通過查閱死者的電腦和手機销钝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進店門湖雹,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人曙搬,你說我怎么就攤上這事。” “怎么了纵装?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵征讲,是天一觀的道長。 經(jīng)常有香客問我橡娄,道長诗箍,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任挽唉,我火速辦了婚禮滤祖,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘瓶籽。我一直安慰自己匠童,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布塑顺。 她就那樣靜靜地躺著汤求,像睡著了一般。 火紅的嫁衣襯著肌膚如雪严拒。 梳的紋絲不亂的頭發(fā)上扬绪,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天,我揣著相機與錄音裤唠,去河邊找鬼挤牛。 笑死,一個胖子當(dāng)著我的面吹牛种蘸,可吹牛的內(nèi)容都是我干的墓赴。 我是一名探鬼主播,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼劈彪,長吁一口氣:“原來是場噩夢啊……” “哼竣蹦!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起沧奴,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤痘括,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后滔吠,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體纲菌,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年疮绷,在試婚紗的時候發(fā)現(xiàn)自己被綠了翰舌。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡冬骚,死狀恐怖椅贱,靈堂內(nèi)的尸體忽然破棺而出懂算,到底是詐尸還是另有隱情,我是刑警寧澤庇麦,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布计技,位于F島的核電站,受9級特大地震影響山橄,放射性物質(zhì)發(fā)生泄漏垮媒。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一航棱、第九天 我趴在偏房一處隱蔽的房頂上張望睡雇。 院中可真熱鬧,春花似錦饮醇、人聲如沸它抱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽抗愁。三九已至,卻和暖如春呵晚,著一層夾襖步出監(jiān)牢的瞬間蜘腌,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工饵隙, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留撮珠,地道東北人。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓金矛,卻偏偏與公主長得像芯急,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子驶俊,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,877評論 2 345

推薦閱讀更多精彩內(nèi)容