91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何快速上手Rollup

發布時間:2021-10-23 15:51:19 來源:億速云 閱讀:129 作者:iii 欄目:web開發

本篇內容主要講解“如何快速上手Rollup”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何快速上手Rollup”吧!

什么是rollup?

系統的了解rollup之前,我們先來簡單了解下What is rollup?

關于rollup的介紹,官方文檔已經寫的很清楚了:

Rollup 是一個 JavaScript 模塊打包器,可以將小塊代碼編譯成大塊復雜的代碼,例如 library 或應用程序。

與Webpack偏向于應用打包的定位不同,rollup.js更專注于Javascript類庫打包。

我們熟知的Vue、React等諸多知名框架或類庫都是通過rollup.js進行打包的。

為什么是rollup?

webpack我相信做前端的同學大家都用過,那么為什么有些場景還要使用rollup呢?這里我簡單對webpack和rollup做一個比較:

總體來說webpack和rollup在不同場景下,都能發揮自身優勢作用。webpack對于代碼分割和靜態資源導入有著“先天優勢”,并且支持熱模塊替換(HMR),而rollup并不支持。

所以當開發應用時可以優先選擇webpack,但是rollup對于代碼的Tree-shaking和ES6模塊有著算法優勢上的支持,若你項目只需要打包出一個簡單的bundle包,并是基于ES6模塊開發的,可以考慮使用rollup。

其實webpack從2.0開始就已經支持Tree-shaking,并在使用babel-loader的情況下還可以支持es6 module的打包。實際上,rollup已經在漸漸地失去了當初的優勢了。但是它并沒有被拋棄,反而因其簡單的API、使用方式被許多庫開發者青睞,如React、Vue等,都是使用rollup作為構建工具的。

快速上手

我們先花大概十分鐘左右的時間來了解下rollup的基本使用以及完成一個hello world。

安裝

首先全局安裝rollup:

npm i rollup -g

目錄準備(hello world)

接著,我們初始化一個如下所示的項目目錄

├── dist # 編譯結果  ├── example # HTML引用例子  │   └── index.html  ├── package.json  └── src # 源碼      └── index.js

首先我們在src/index.js中寫入如下代碼:

console.log("柯森");

然后在命令行執行以下命令:

rollup src/index.js -f umd -o dist/bundle.js

執行命令,我們即可在dist目錄下生成bundle.js文件:

(function (factory) {   typeof define === 'function' && define.amd ? define(factory) :   factory();  }((function () { 'use strict';   console.log("柯森");  })));

這時,我們再在example/index.html中引入上面打包生成的bundle.js文件,打開瀏覽器:如我們所預料的,控制臺輸出了柯森。

如何快速上手Rollup

到這里,我們就用rollup打包了一個最最簡單的demo。

可能很多同學看到這里對于上面命令行中的參數不是很明白,我依次說明下:

  •  -f。-f參數是--format的縮寫,它表示生成代碼的格式,amd表示采用AMD標準,cjs為CommonJS標準,esm(或 es)為ES模塊標準。-f的值可以為amd、cjs、system、esm('es’也可以)、iife或umd中的任何一個。

  •  -o。-o指定了輸出的路徑,這里我們將打包后的文件輸出到dist目錄下的bundle.js

其實除了這兩個,還有很多其他常用的命令(這里我暫且列舉剩下兩個也比較常用的,完整的rollup 命令行參數):

  •  -c。指定rollup的配置文件。

  •  -w。監聽源文件是否有改動,如果有改動,重新打包。

使用配置文件(rollup.config.js)

使用命令行的方式,如果選項少沒什么問題,但是如果添加更多的選項,這種命令行的方式就顯得麻煩了。

為此,我們可以創建配置文件來囊括所需的選項

在項目中創建一個名為rollup.config.js的文件,增加如下代碼:

export default {    input: ["./src/index.js"],    output: {      file: "./dist/bundle.js",      format: "umd",      name: "experience",    },  };

然后命令行執行:

rollup -c

打開dist/bundle.js文件,我們會發現和上面采用命令行的方式打包出來的結果是一樣的。

這里,我對配置文件的選項做下簡單的說明:

  •  input表示入口文件的路徑(老版本為 entry,已經廢棄)

  •  output表示輸出文件的內容,它允許傳入一個對象或一個數組,當為數組時,依次輸出多個文件,它包含以下內容:

    •  output.file:輸出文件的路徑(老版本為 dest,已經廢棄)

    •  output.format:輸出文件的格式

    •  output.banner:文件頭部添加的內容

    •  output.footer:文件末尾添加的內容

到這里,相信你已經差不多上手rollup了。

進階

但是,這對于真實的業務場景是遠遠不夠的。

下面,我將介紹rollup中的幾種常用的插件以及external屬性、tree-shaking機制。

resolve插件

為什么要使用resolve插件

在上面的入門案例中,我們打包的對象是本地的js代碼和庫,但實際開發中,不太可能所有的庫都位于本地,我們大多會通過npm下載遠程的庫。

與webpack和browserify這樣的其他捆綁包不同,rollup不知道如何打破常規去處理這些依賴。因此我們需要添加一些配置。

resolve插件使用

首先在我們的項目中添加一個依賴the-answer,然后修改src/index.js文件:

import answer from "the-answer";  export default function () {    console.log("the answer is " + answer);  }

執行npm run build。

這里為了方便,我將原本的rollup -c -w添加到了package.json的scripts中:"build": "rollup -c -w"

會得到以下報錯:

如何快速上手Rollup

打包后的bundle.js仍然會在Node.js中工作,但是the-answer不包含在包中。為了解決這個問題,將我們編寫的源碼與依賴的第三方庫進行合并,rollup.js為我們提供了resolve插件。

首先,安裝resolve插件:

npm i -D @rollup/plugin-node-resolve

修改配置文件rollup.config.js:

import resolve from "@rollup/plugin-node-resolve";  export default {    input: ["./src/index.js"],    output: {      file: "./dist/bundle.js",      format: "umd",      name: "experience",    },    plugins: [resolve()],  };

這時再次執行npm run build,可以發現報錯已經沒有了:

如何快速上手Rollup

打開dist/bundle.js文件:

(function (global, factory) {    typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :    typeof define === 'function' && define.amd ? define(factory) :    (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.experience = factory());  }(this, (function () { 'use strict';    var index = 42;    function index$1 () {      console.log("the answer is " + index);    }    return index$1;  })));

打包文件bundle.js中已經包含了引用的模塊。

有些場景下,雖然我們使用了resolve插件,但可能我們仍然想要某些庫保持外部引用狀態,這時我們就需要使用external屬性,來告訴rollup.js哪些是外部的類庫。

external 屬性

修改rollup.js的配置文件:

import resolve from "@rollup/plugin-node-resolve";  export default {    input: ["./src/index.js"],    output: {      file: "./dist/bundle.js",      format: "umd",      name: "experience",    },    plugins: [resolve()],    external: ["the-answer"],  };

重新打包,打開dist/bundle.js文件:

(function (global, factory) {    typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory(require('the-answer')) :    typeof define === 'function' && define.amd ? define(['the-answer'], factory) :    (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.experience = factory(global.answer));  }(this, (function (answer) { 'use strict';    function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }    var answer__default = /*#__PURE__*/_interopDefaultLegacy(answer);    function index () {      console.log("the answer is " + answer__default['default']);    }    return index;  })));

這時我們看到the-answer已經是做為外部庫被引入了。

commonjs插件

為什么需要commonjs插件

rollup.js編譯源碼中的模塊引用默認只支持 ES6+的模塊方式import/export。然而大量的npm模塊是基于CommonJS模塊方式,這就導致了大量 npm模塊不能直接編譯使用。

因此使得rollup.js編譯支持npm模塊和CommonJS模塊方式的插件就應運而生:@rollup/plugin-commonjs。

commonjs插件使用

首先,安裝該模塊:

npm i -D @rollup/plugin-commonjs

然后修改rollup.config.js文件:

import resolve from "@rollup/plugin-node-resolve";  import commonjs from "@rollup/plugin-commonjs";  export default {    input: ["./src/index.js"],    output: {      file: "./dist/bundle.js",      format: "umd",      name: "experience",    },    plugins: [resolve(), commonjs()],    external: ["the-answer"],  };

babel插件

為什么需要babel插件?

我們在src目錄下添加es6.js文件(?? 這里我們使用了 es6 中的箭頭函數):

const a = 1;  const b = 2;  console.log(a, b);  export default () => {    return a + b;  };

然后修改rollup.config.js配置文件:

import resolve from "@rollup/plugin-node-resolve";  import commonjs from "@rollup/plugin-commonjs";  export default {    input: ["./src/es6.js"],    output: {      file: "./dist/esBundle.js",      format: "umd",      name: "experience",    },    plugins: [resolve(), commonjs()],    external: ["the-answer"],  };

執行打包,可以看到dist/esBundle.js文件內容如下:

(function (global, factory) {    typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :    typeof define === 'function' && define.amd ? define(factory) :    (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.experience = factory());  }(this, (function () { 'use strict';    const a = 1;    const b = 2;    console.log(a, b);    var es6 = () => {      return a + b;    };    return es6;  })));

可以看到箭頭函數被保留下來,這樣的代碼在不支持ES6的環境下將無法運行。我們期望在rollup.js打包的過程中就能使用babel完成代碼轉換,因此我們需要babel插件。

babel插件的使用

首先,安裝:

npm i -D @rollup/plugin-babel

同樣修改配置文件rollup.config.js:

import resolve from "@rollup/plugin-node-resolve";  import commonjs from "@rollup/plugin-commonjs";  import babel from "@rollup/plugin-babel";  export default {    input: ["./src/es6.js"],    output: {      file: "./dist/esBundle.js",      format: "umd",      name: "experience",    },    plugins: [resolve(), commonjs(), babel()],    external: ["the-answer"], };

然后打包,發現會出現報錯:

如何快速上手Rollup

提示我們缺少@babel/core,因為@babel/core是babel的核心。我們來進行安裝:

npm i @babel/core

再次執行打包,發現這次沒有報錯了,但是我們嘗試打開dist/esBundle.js:

(function (global, factory) {    typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :    typeof define === 'function' && define.amd ? define(factory) :    (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.experience = factory());  }(this, (function () { 'use strict';    const a = 1;    const b = 2;    console.log(a, b);    var es6 = (() => {      return a + b;    });    return es6;  })));

可以發現箭頭函數仍然存在,顯然這是不正確的,說明我們的babel插件沒有起到作用。這是為什么呢?

原因是由于我們缺少.babelrc文件,添加該文件:

{    "presets": [      [        "@babel/preset-env",        {          "modules": false,          // "useBuiltIns": "usage"        }      ]    ]  }

我們看.babelrc配置了preset env,所以先安裝這個插件:

npm i @babel/preset-env

這次再次執行打包,我們打開dist/esBundle.js文件:

(function (global, factory) {    typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :    typeof define === 'function' && define.amd ? define(factory) :    (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.experience = factory());  }(this, (function () { 'use strict';    var a = 1;    var b = 2;    console.log(a, b);    var es6 = (function () {      return a + b;    });    return es6;  })));

可以看到箭頭函數被轉換為了function,說明babel插件正常工作。

json插件

為什么要使用json插件?

在src目錄下創建json.js文件:

import json from "../package.json";  console.log(json.author);

內容很簡單,就是引入package.json,然后去打印author字段。

修改rollup.config.js配置文件:

import resolve from "@rollup/plugin-node-resolve";  import commonjs from "@rollup/plugin-commonjs";  import babel from "@rollup/plugin-babel";  export default {    input: ["./src/json.js"],    output: {      file: "./dist/jsonBundle.js",      format: "umd",      name: "experience",    },    plugins: [resolve(), commonjs(), babel()],    external: ["the-answer"],  };

執行打包,發現會發生如下報錯:

如何快速上手Rollup

提示我們缺少@rollup/plugin-json插件來支持json文件。

json插件的使用

來安裝該插件:

npm i -D @rollup/plugin-json

同樣修改下配置文件,將插件加入plugins數組即可。

然后再次打包,發現打包成功了,我們打開生成的dist/jsonBundle目錄:

(function (factory) {    typeof define === 'function' && define.amd ? define(factory) :    factory();  }((function () { 'use strict';    var name = "rollup-experience";    var version = "1.0.0";    var description = "";    var main = "index.js";    var directories = {     example: "example"    };    var scripts = {     build: "rollup -c -w",     test: "echo \"Error: no test specified\" && exit 1"    };    var author = "Cosen";    var license = "ISC";    var dependencies = {     "@babel/core": "^7.11.6",     "@babel/preset-env": "^7.11.5",     "the-answer": "^1.0.0"    };    var devDependencies = {     "@rollup/plugin-babel": "^5.2.0",     "@rollup/plugin-commonjs": "^15.0.0",     "@rollup/plugin-json": "^4.1.0",     "@rollup/plugin-node-resolve": "^9.0.0"    };    var json = {     name: name,     version: version,    description: description,     main: main,     directories: directories,     scripts: scripts,     author: author,     license: license,     dependencies: dependencies,     devDependencies: devDependencies    };     console.log(json.author);  })));

完美!!

tree-shaking機制

這里我們以最開始的src/index.js為例進行說明:

import answer from "the-answer";  export default function () {    console.log("the answer is " + answer);  }

修改上述文件:

const a = 1;  const b = 2;  export default function () {    console.log(a + b);  }

執行打包。打開dist/bundle.js文件:

(function (global, factory) {    typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :    typeof define === 'function' && define.amd ? define(factory) :    (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.experience = factory());  }(this, (function () { 'use strict';    var a = 1;    var b = 2;    function index () {      console.log(a + b);    }    return index;  })));

再次修改src/index.js文件:

const a = 1;  const b = 2;  export default function () {    console.log(a);  }

再次執行打包,打開打包文件:

(function (global, factory) {    typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :    typeof define === 'function' && define.amd ? define(factory) :    (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.experience = factory());  }(this, (function () { 'use strict';    var a = 1;    function index () {      console.log(a);    }    return index;  })));

發現了什么?

我們發現關于變量b的定義沒有了,因為源碼中并沒有用到這個變量。這就是ES模塊著名的tree-shaking機制,它動態地清除沒有被使用過的代碼,使得代碼更加精簡,從而可以使得我們的類庫獲得更快的加載速度。

到此,相信大家對“如何快速上手Rollup”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

蓝山县| 辽宁省| 桦甸市| 镇平县| 邵阳市| 吉安县| 盐边县| 大足县| 隆尧县| 苍梧县| 济源市| 乐东| 栾川县| 灵寿县| 汝城县| 兴隆县| 靖边县| 磐安县| 延安市| 兰溪市| 鄱阳县| 兴国县| 扶绥县| 高雄市| 邢台市| 广平县| 屏东市| 玛纳斯县| 外汇| 客服| 措美县| 安陆市| 宁城县| 靖安县| 满洲里市| 兴和县| 榆社县| 伊宁县| 新田县| 如皋市| 富宁县|