Rollup.js打包代码

简介: Rollup.js打包代码

Rollup 是一个 JavaScript 模块打包器


中文网:https://www.rollupjs.com/

英文网:https://www.rollupjs.org/


安装


npm install --global rollup

简单示例

main.js


console.log("hello rollup");

打包


rollup --help # 可以查看
# 浏览器
rollup main.js --file bundle.js --format iife

打包结果


bundle.js


(function () {
  "use strict";
  console.log("hello rollup");
})();

第一个 Buddle

src/main.js


// src/main.js
import foo from "./foo.js";
export default function () {
  console.log(foo);
}

src/foo.js


// src/foo.js
export default "hello world!";

打包


rollup src/main.js -o bundle.js -f cjs

使用配置文件

rollup.config.js


// rollup.config.js
export default {
  input: "src/main.js",
  output: {
    file: "bundle.js",
    format: "cjs",
  },
};

打包


# 默认使用rollup.config.js
rollup -c

插件

https://github.com/rollup/plugins/


npm init -y
npm install --save-dev rollup-plugin-json

从 json 文件中读取数据


package.json


{
  "name": "rollup-demo",
  "version": "1.0.0",
  "description": "",
  "main": "",
  "dependencies": {},
  "devDependencies": {
    "rollup-plugin-json": "^4.0.0"
  },
  "scripts": {
    "build": "rollup -c"
  },
  "keywords": [],
  "author": "",
  "license": "ISC"
}

src/main.js


// src/main.js
import { version } from "../package.json";
export default function () {
  console.log("version " + version);
}

配置文件加入 JSON 插件

rollup.config.js


// rollup.config.js
import json from "rollup-plugin-json";
export default {
  input: "src/main.js",
  output: {
    file: "bundle.js",
    format: "cjs",
  },
  plugins: [json()],
};

编译

npm run build

编译结果


"use strict";
var version = "1.0.0";
// src/main.js
function main() {
  console.log("version " + version);
}
module.exports = main;

总结

配置打包和开发环境启动项


package.json


{
  "name": "rollup-demo",
  "version": "1.0.0",
  "description": "",
  "main": "",
  "dependencies": {},
  "devDependencies": {
    "rollup-plugin-json": "^4.0.0"
  },
  "scripts": {
    "dev": "rollup --config --watch",
    "build": "rollup --config"
  },
  "keywords": [],
  "author": "",
  "license": "ISC"
}

配置即使打包


rollup.config.js

// rollup.config.js
import json from "rollup-plugin-json";
export default {
  input: "src/main.js",
  output: {
    file: "bundle.js",
    format: "iife",
  },
  plugins: [json()],
  watch: {
    exclude: "node_modules/**",
  },
};
相关文章
|
9天前
|
JavaScript
短小精悍的js代码
【10月更文挑战第17天】
110 58
|
14天前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
281 1
|
19天前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 来检查代码规范并自动格式化 Vue.js 代码。
【10月更文挑战第7天】随着前端开发技术的快速发展,代码规范和格式化工具变得尤为重要。本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 来检查代码规范并自动格式化 Vue.js 代码。通过安装和配置这两个工具,可以确保代码风格一致,提升团队协作效率和代码质量。
170 2
|
22天前
|
JavaScript 前端开发 内存技术
js文件的入口代码及需要入口代码的原因
js文件的入口代码及需要入口代码的原因
31 0
|
1天前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤
随着前端开发技术的快速发展,代码规范和格式化工具变得尤为重要。本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤。通过这些工具,可以显著提升编码效率和代码质量。
10 4
|
3天前
|
JSON 移动开发 数据格式
html5+css3+js移动端带歌词音乐播放器代码
音乐播放器特效是一款html5+css3+js制作的手机移动端音乐播放器代码,带歌词显示。包括支持单曲循环,歌词显示,歌曲搜索,音量控制,列表循环等功能。利用json获取音乐歌单和歌词,基于html5 audio属性手机音乐播放器代码。
31 6
|
17天前
|
JavaScript 前端开发 开发者
如何在 VSCode 中使用 ESLint 和 Prettier 检查并自动格式化 Vue.js 代码,提升团队协作效率和代码质量。
【10月更文挑战第9天】随着前端开发技术的发展,代码规范和格式化工具变得至关重要。本文介绍如何在 VSCode 中使用 ESLint 和 Prettier 检查并自动格式化 Vue.js 代码,提升团队协作效率和代码质量。通过安装插件、配置 ESLint 和 Prettier,以及设置 VSCode,实现代码实时检查和格式化,确保代码风格一致。
12 2
|
18天前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查并自动格式化 Vue.js 代码,提升代码质量和团队协作效率。
【10月更文挑战第8天】本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查并自动格式化 Vue.js 代码,提升代码质量和团队协作效率。通过安装 VSCode 插件、配置 ESLint 和 Prettier,实现代码规范检查和自动格式化,确保代码风格一致,提高可读性和维护性。
25 2
|
18天前
|
JavaScript 中间件 Shell
Node.js JXcore 打包
10月更文挑战第8天
21 1
|
24天前
|
JavaScript 前端开发
电话号码正则表达式 代码 javascript+html,JS正则表达式判断11位手机号码
电话号码正则表达式 代码 javascript+html,JS正则表达式判断11位手机号码
58 1