国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Babel插件開發(fā)入門示例詳解

Muninn / 1979人閱讀

摘要:的工作過程的處理主要過程解析轉(zhuǎn)換生成。代碼轉(zhuǎn)換處理,處理工具插件等就是在這個階段進行代碼轉(zhuǎn)換,返回新的。若感興趣了解更多內(nèi)容,插件中文開發(fā)文檔提供了很多詳細資料。

Babel簡介

Babel是Javascript編譯器,是種代碼到代碼的編譯器,通常也叫做『轉(zhuǎn)換編譯器』。

Babel的工作過程

Babel的處理主要過程:解析(parse)、轉(zhuǎn)換(transform)、生成(generate)。

代碼解析
詞法分析和語法分析構(gòu)造AST。

代碼轉(zhuǎn)換
處理AST,處理工具、插件等就是在這個階段進行代碼轉(zhuǎn)換,返回新的AST。

代碼生成
遍歷AST,輸出代碼字符串。

所以我們需要對AST有一定了解才能進行Babel插件開發(fā)。

AST

在這整個過程中,都是圍繞著抽象語法樹(AST)來進行的。在Javascritp中,AST,簡單來說,就是一個記錄著代碼語法結(jié)構(gòu)的Object。感興趣的同學可到https://astexplorer.net/ 去深入體驗
比如下面的代碼:

import {Button} from "antd";

import Card from "antd/button/lib/index.js";

轉(zhuǎn)換成AST后如下,

{
  "type": "Program",
  "start": 0,
  "end": 253,
  "body": [
    {
      "type": "ImportDeclaration",
      "start": 179,
      "end": 207,
      "specifiers": [
        {
          "type": "ImportSpecifier",
          "start": 187,
          "end": 193,
          "imported": {
            "type": "Identifier",
            "start": 187,
            "end": 193,
            "name": "Button"
          },
          "local": {
            "type": "Identifier",
            "start": 187,
            "end": 193,
            "name": "Button"
          }
        }
      ],
      "source": {
        "type": "Literal",
        "start": 200,
        "end": 206,
        "value": "antd",
        "raw": ""antd""
      }
    },
    {
      "type": "ImportDeclaration",
      "start": 209,
      "end": 253,
      "specifiers": [
        {
          "type": "ImportDefaultSpecifier",
          "start": 216,
          "end": 220,
          "local": {
            "type": "Identifier",
            "start": 216,
            "end": 220,
            "name": "Card"
          }
        }
      ],
      "source": {
        "type": "Literal",
        "start": 226,
        "end": 252,
        "value": "antd/button/lib/index.js",
        "raw": ""antd/button/lib/index.js""
      }
    }
  ],
  "sourceType": "module"
}
插件開發(fā)思路

確定我們需要處理的節(jié)點類型

處理節(jié)點

返回新的節(jié)點

簡單插件結(jié)構(gòu)

插件必須是一個函數(shù),根據(jù)官方文檔要求,形式如下:

module.exports = function ({ types: t }) {
    return {
        visitor: {
            ImportDeclaration(path, source){
                //todo
            },
            FunctionDeclaration(path, source){
                //todo
            },
        }    
    }
}

types來自@babel/types工具類,主要用途是在創(chuàng)建AST的過程中判斷各種語法的類型和節(jié)點構(gòu)造。

實現(xiàn)示例

很多同學用過 babel-plugin-import ,它幫助我們在使用一些JS類庫是達到按需加載。其實,該插件幫助我們做了如下代碼轉(zhuǎn)換:

//from
import {Button } from "antd";

//to
import Button from "antd/es/button";
import "antd/es/button/style.css"; 

我們先看看兩者的AST有何差別,以幫助我們對轉(zhuǎn)換有個清晰的認識:

轉(zhuǎn)換前:

 
[{
      "type": "ImportDeclaration",
      "start": 6,
      "end": 45,
      "specifiers": [
        {
          "type": "ImportSpecifier",
          "start": 14,
          "end": 20,
          "imported": {
            "type": "Identifier",
            "start": 14,
            "end": 20,
            "name": "Button"
          },
          "local": {
            "type": "Identifier",
            "start": 14,
            "end": 20,
            "name": "Button"
          }
        }
      ],
      "source": {
        "type": "Literal",
        "start": 28,
        "end": 44,
        "value": "antd/es/button",
        "raw": ""antd/es/button""
      }
    }]
    

轉(zhuǎn)換后:

 [{
  "type": "ImportDeclaration",
  "start": 5,
  "end": 41,
  "specifiers": [
    {
      "type": "ImportDefaultSpecifier",
      "start": 12,
      "end": 18,
      "local": {
        "type": "Identifier",
        "start": 12,
        "end": 18,
        "name": "Button"
      }
    }
  ],
  "source": {
    "type": "Literal",
    "start": 24,
    "end": 40,
    "value": "antd/es/button",
    "raw": ""antd/es/button""
  }
},
{
  "type": "ImportDeclaration",
  "start": 46,
  "end": 76,
  "specifiers": [],
  "source": {
    "type": "Literal",
    "start": 53,
    "end": 75,
    "value": "antd/es/button/style",
    "raw": ""antd/es/button/style""
  }
}]

對比兩棵樹,我們應該有個大致的思路。在轉(zhuǎn)換過程中,我們還需要一些參數(shù),這些參數(shù)在配置文件(package.json或者.babelrc)中,提供了一些自定義配置,比如antd的按需加載:

["import",{libraryName:"antd",libraryDireactory:"es","style":"css"}]

現(xiàn)在我們開始嘗試實現(xiàn)這個插件吧:

module.exports = function ({ types: t }) {
return {
    visitor: {
        ImportDeclaration(path, source) {
            
            //取出參數(shù)
            const { opts: { libraryName, libraryDirectory="lib", style="css" } } = source;
            //拿到老的AST節(jié)點
            let node = path.node

            if(node.source.value !== libraryName){
                return;
            }
            //創(chuàng)建一個數(shù)組存入新生成AST
            let newImports = [];
            //構(gòu)造新節(jié)點
            path.node.specifiers.forEach(item => {
                newImports.push(t.importDeclaration([t.importDefaultSpecifier(item.local)], t.stringLiteral(`${libraryName}/${libraryDirectory}/${item.local.name}`)));
                newImports.push(t.importDeclaration([], t.stringLiteral(`${libraryName}/${libraryDirectory}/style.${style}`)))
            });
            //替換原節(jié)點
            path.replaceWithMultiple(newImports);                
        }
    }
}

}

現(xiàn)在,簡單版本的@babel-plugin-import的babel插件我們已經(jīng)完成了。
若感興趣了解更多內(nèi)容,babel插件中文開發(fā)文檔提供了很多詳細資料。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/106485.html

相關(guān)文章

  • Babel 快速入門

    摘要:快速體驗安裝依賴新建文件夾,在命令行里進入該文件夾,并執(zhí)行如下命令生成文件是內(nèi)置的一個,可通過命令行操作來編譯文件。入門為了確保轉(zhuǎn)換后的代碼能正常的運行,最好在代碼之前引入這是一個實現(xiàn)了部分特性的包。參考中文網(wǎng)入門 簡介 Babel 是一個 JavaScript 編譯器,可將我們代碼中的 ES6 語法轉(zhuǎn)換為 ES5 的語法,使我們的代碼能在不支持 ES6 語法的環(huán)境中正常運行。配合一些...

    NoraXie 評論0 收藏0
  • Babel入門插件開發(fā)

    摘要:最近的技術(shù)項目里大量用到了需要修改源文件代碼的需求,也就理所當然的用到了及其插件開發(fā)。在這里我要推薦一款實現(xiàn)了這些標簽的插件,建議在你的項目中加入這個插件并用起來,不用再艱難的書寫三元運算符,會大大提升你的開發(fā)效率。具體可以參見插件手冊。 最近的技術(shù)項目里大量用到了需要修改源文件代碼的需求,也就理所當然的用到了Babel及其插件開發(fā)。這一系列專題我們介紹下Babel相關(guān)的知識及使用。 ...

    Jinkey 評論0 收藏0
  • 前端文檔收集

    摘要:系列種優(yōu)化頁面加載速度的方法隨筆分類中個最重要的技術(shù)點常用整理網(wǎng)頁性能管理詳解離線緩存簡介系列編寫高性能有趣的原生數(shù)組函數(shù)數(shù)據(jù)訪問性能優(yōu)化方案實現(xiàn)的大排序算法一怪對象常用方法函數(shù)收集數(shù)組的操作面向?qū)ο蠛驮屠^承中關(guān)鍵詞的優(yōu)雅解釋淺談系列 H5系列 10種優(yōu)化頁面加載速度的方法 隨筆分類 - HTML5 HTML5中40個最重要的技術(shù)點 常用meta整理 網(wǎng)頁性能管理詳解 HTML5 ...

    jsbintask 評論0 收藏0
  • 前端文檔收集

    摘要:系列種優(yōu)化頁面加載速度的方法隨筆分類中個最重要的技術(shù)點常用整理網(wǎng)頁性能管理詳解離線緩存簡介系列編寫高性能有趣的原生數(shù)組函數(shù)數(shù)據(jù)訪問性能優(yōu)化方案實現(xiàn)的大排序算法一怪對象常用方法函數(shù)收集數(shù)組的操作面向?qū)ο蠛驮屠^承中關(guān)鍵詞的優(yōu)雅解釋淺談系列 H5系列 10種優(yōu)化頁面加載速度的方法 隨筆分類 - HTML5 HTML5中40個最重要的技術(shù)點 常用meta整理 網(wǎng)頁性能管理詳解 HTML5 ...

    muddyway 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<