Browserify使用指南(转)

让浏览器加载Nodejs模块

目前NPM上有二十多万个NodeJS模块,它们都是通过CMD的方式打包的,除了特定的可以使用CMD模块加载器加载的模块,大部分nodejs模块无法直接使用到浏览器环境中。

Browserify是一个供浏览器环境使用的模块打包工具,像在node环境一样,也是通过require(‘modules‘)来组织模块之间的引用和依赖,既可以引用npm中的模块,也可以引用自己写的模块,然后打包成js文件,再在页面中通过<script>标签加载。

当然对于很多NodeJS模块,比如涉及到io操作的模块,就算通过browserify打包后肯定也无法运行在浏览器环境中,这种情况下就会用到为它们重写的支持浏览器端的分支模块,可以在browserify search搜索到这些模块。

用例

比如写一个入口main.js文件,使用require()来引用其它模块,包括相对目录中的‘./foo.js‘‘../lib/bar.js‘,还有在node_modules/目录中的名为‘gamma‘的模块。

browserify通过node’s module lookup algorithm来查找node_modules/中的模块)

// main.js
var foo = require(‘./foo.js‘);
var bar = require(‘../lib/bar.js‘);
var gamma = require(‘gamma‘);

var elem = document.getElementById(‘result‘);
var x = foo(100) + bar(‘baz‘);
elem.textContent = gamma(x);

众所周知,这些被引用的模块会用通过module.exportsexports输出它们的功能接口:

// foo.js
module.exports = function (n) { return n * 111 }

接下来就可以用browserify命令对它们进行打包了:

$ browserify main.js > bundle.js

main.js和它所引用的模块会按依赖序列整体打包到bundle.js

browserify使用required来查找require()依赖队列。

接下来,就可以在html中加载这个文件<script src="bundle.js"></script>来运行了。

安装Browserify

$ npm install -g browserify

通过命令行使用

Usage: browserify [entry files] {OPTIONS}

常用选项:

    --outfile, -o  指定打包后的输出文件
                   如果不指定,将输到stdout,比如shell

    --require, -r  通过模块名或文件路径指定需要打包到bundle中的其他模块
                   Optionally use a colon separator to set the target

      --entry, -e  入口文件

     --ignore, -i  打包过程中忽略依赖的某个文件,当成空模块打包,引用它不会报错

    --exclude, -u  打包过程中排除依赖的某个文件,比忽略选项更严格,引用它会报错

   --external, -x  指定某个文件不要打包到bundle,它可能会打包在其他的bundle中,比如jquery会打包到公共的bundle中

  --transform, -t  指定打包过程中使用的转换模块

    --command, -c  指定打包过程中使用的命令行转换

  --standalone -s  生成UMD模式的bundle模块,可以在AMD、CMD中使用

       --debug -d  生成source maps,并被注释到bundle.js的尾部

       --help, -h  显示帮助

高级选项:

  --insert-globals, --ig, --fast    [default: false]

    如果设置为true,会跳过代码分析,强制在每个模块的闭包作用域中插入如下参数
    process, global, __filename, and __dirname

    优点: 打包速度快
    缺点: 生成多余的参数

  --insert-global-vars, --igv

    需要在代码分析中检测和定义的全局变量,需要和--insert-globals一起使用
    默认包括 __filename,__dirname,process,Buffer,global 用逗号分隔

  --detect-globals, --dg            [default: true]

    在代码分析过程中检测全局变量 process, global, __filename, and __dirname

    优点: 像npm模块那样工作
    缺点: 打包速度慢

  --ignore-missing, --im            [default: false]

    忽略 `require()` 引用

  --noparse=FILE

    对于默写确定不包含`require()`的文件,忽略他们的解析过程(比如jquery),加快打包速度

  --no-builtins

    如果打包后的文件要在node环境中使用,请使用这个选项,保证node内置模块不被打包到bundle中

  --no-commondir

    不是用相对路径,__filename,__dirname会被解析成绝对路径

  --no-bundle-external

    不打包扩展模块

  --bare

    --no-builtins --no-commondir --insert-global-vars "__filename,__dirname" 的别名
    如果bundle在node环境中运行,请使用--bare

  --no-browser-field, --no-bf

    忽略package.json中的browser属性
    如果bundle在node环境中运行

  --node

    --bare --no-browser-field 的别名

  --full-paths

    所有模块都是用绝对路径进行引用

  --deps

    输出模块的依赖序列(一个数组)

  --list

    输出所有模块的路径列表

  --extension=EXTENSION

    指定有效的模块文件扩展名

  --global-transform=MODULE, -g MODULE

    指定一个全局的转换模块

  --plugin=MODULE, -p MODULE

    注册一个插件模块

如何在转换模块和插件再插入参数项:

  使用subarg语法在中括号中插入子命令,比如:

    -t [ foo -x 3 --beep ]

  会这样执行

    foo(file, { x: 3, beep: true })

nodejs内置模块的转换

理想情况下,大部分不涉及io操作的模块可以在浏览器中直接运行。

对于nodejs内置模块,在require()它们的时候,会被转换成如下模块来打包,以适配浏览器环境。

另外, 如果是用到了如下5个全局变量,它们会在打包过程中被改写成可以适配浏览器环境的。

  • process
  • Buffer
  • global 全局变量window
  • __filename - 文件名
  • __dirname - 文件路径

其他用例

在全局作用域中(模块外部)引用指定模块

$ browserify -r through -r duplexer -r ./my-file.js:my-module > bundle.js

在页面中直接引用这些外部模块

<script src="bundle.js"></script>
<script>
  var through = require(‘through‘);
  var duplexer = require(‘duplexer‘);
  var myModule = require(‘my-module‘);
  /* ... */
</script>

导出source maps文件

使用exorcist导出.js.map文件

$ browserify main.js --debug | exorcist bundle.js.map > bundle.js

导出多个包

如果多个页面的打包结果中包含公共的模块,可以将公共模块(common.js)单独打包出来,以节省请求流量并优化缓存策略

# beep.js
var robot = require(‘./robot.js‘);
console.log(robot(‘beep‘));
# boop.js
var robot = require(‘./robot.js‘);
console.log(robot(‘boop‘));

这两个文件都引用了robot.js

# robot.js
module.exports = function (s) { return s.toUpperCase() + ‘!‘ };
# 把公共的模块打包成common.js
$ browserify -r ./robot.js > static/common.js
$ browserify -x ./robot.js beep.js > static/beep.js
$ browserify -x ./robot.js boop.js > static/boop.js

如何引用?

<!--beep.html-->
<script src="common.js"></script>
<script src="beep.js"></script>
<!--boop.html-->
<script src="common.js"></script>
<script src="boop.js"></script>

上面这个用例,还可以用插件解决,会更方便

api

Browserify本身也是一个nodejs模块,提供的方法大致和上面介绍的命令行选项相同,具体的api请参考browserify methods,这里不再敖述。

var browserify = require(‘browserify‘);
var b = browserify();
b.add(‘./browser/main.js‘);
b.bundle().pipe(process.stdout);

events api

//当文件被进行打包时出发,可以用来监听文件变化来重新进行打包
b.on(‘file‘, function (file, id, parent) {})
b.pipeline.on(‘file‘, function (file, id, parent) {})

// 当每个package.json被读取时触发
b.on(‘package‘, function (pkg) {})
b.pipeline.on(‘package‘, function (pkg) {})

// 当执行`.bundle()`时触发
b.on(‘bundle‘, function (bundle) {})

// 当执行`.reset()`时触发
b.on(‘reset‘, function () {})

// 当一个文件被转换时触
b.on(‘transform‘, function (tr, file) {})
b.pipeline.on(‘transform‘, function (tr, file) {})

package.json

browserify会先通过package.json中的"main"属性来查找模块入口,如果没有"main"属性,就在目录中搜索"index.js"文件。当然,package.json中还定义了一些browserify特有的属性:

browser属性

browser“属性用来优先指定browserify打包是的模块入口文件,这样可以和"main"属性区分开

"browser": "./browser.js"

还可以指定细分的打包替换文件

"browser": {
  "fs": "level-fs",
  "./lib/ops.js": "./browser/opts.js"
}

browserify.transform

package.json中指定转换模块,可以打包过程中自动执行

"browserify": { "transform": [ "brfs" ] }

使用插件

对于一些更先进的用例,转换模块并不能满足需求,插件是更适合的选择。插件是以包实例为其第一个参数,其他属性作为后面的参数。插件可以用来做一些转换模块做不到的花哨功能。比如factor-bundle插件可以用来自动生成多个入口文件共用的common.js模块。

$ browserify x.js y.js -p [ factor-bundle -o bundle/x.js -o bundle/y.js ]   > bundle/common.js

参考链接

转自:http://zhaoda.net/2015/10/16/browserify-guide/

时间: 2024-07-29 21:50:58

Browserify使用指南(转)的相关文章

2015超实用的前端开发指南

[编者按]感谢@lenville对< A Baseline for Front-End [JS] Developers: 2015>的翻译,该文章全面而系统地介绍了前端开发者所应掌握的关键技术及最流行.实用的工具,尤其对于JS开发者大有裨益. 大约三年前,我写了一篇< 前端开发者的基本技能 >,嗯,那大概是我最出名的一篇文章.三年后,仍然有人在Twitter上@我询问如何开始学习前端知识. 在某种程度上,我曾经写下的文字历经了时间的考验:令我感到震惊的是,2012年我写的那篇文章并

你知道这些前端开发指南吗

JavaScript 记忆回到2009年,如果你在文章里读到类似“HTML5将会在2014年定稿使用”的预言,是否看起来那一天还很遥远?如果当时你这样想,你将要准备好迎接缓慢更新但是稳步向前的ES6(现在被称为ES2015,这个名称已经随处可见),也就是下一个版本的JavaScript.准备与ES6——啊不对,ES2015——接轨吧,毫无疑问,这是接下来在JavaScript领域中最重要的事情.ES6 classes.真正的隐私.更好的函数和参数.可引入(import)的模块以及许多其它特性,一

最全解析如何正确学习JavaScript指南,必看!

划重点 鉴于时不时,有同学私信问我:怎么学前端的问题.这里统一回复一下,如下次再遇到问我此问题同学,就直接把本文链接地址发给你了. "前端怎么学"应该因人而异,别人的方法未必适合自己.就说说我的学习方法吧:我把大部分时间放在学习js上了.因为这个js的学习曲线,先平后陡.项目实践和练习啥的,我不说了,主要说下工作之外的时间利用问题.我是怎么学的呢,看书,分析源码.个人这几天统计了一下,前端书籍目前看了50多本吧,大部分都是js的.市面上的书基本,差不多都看过. 第一个问题:看书有啥好处

微信Android接入指南

注:本文为微信Android终端开发工具的新手使用教程,只涉及教授SDK的使用方法,默认读者已经熟悉IDE的基本使用方法(本文以Eclipse为例),以及具有一定的编程知识基础等. 1.申请你的AppID 请到 开发者应用登记页面 进行登记,登记并选择移动应用进行设置后,将该应用提交审核,只有审核通过的应用才能进行开发. 2.下载微信终端开发工具包 开发工具包主要包含3部分内容:(其中,只有libammsdk.jar是必须的) - libammsdk.jar(每个第三方应用必须要导入该sdk库,

【资源共享】Rockchip I2C 开发指南 V1.0

2C设备的设备应用非常广泛,常见的包含重力传感器,触摸屏驱动芯片,音频解码等 这个文档是RK3399的I2C开发文档:<Rockchip I2C 开发指南 V1.0> 内容预览: 下载地址:http://developer.t-firefly.com/thread-12495-1-1.html

Spark性能优化指南——高级篇

Spark性能优化指南--高级篇 [TOC] 前言 继基础篇讲解了每个Spark开发人员都必须熟知的开发调优与资源调优之后,本文作为<Spark性能优化指南>的高级篇,将深入分析数据倾斜调优与shuffle调优,以解决更加棘手的性能问题. 数据倾斜调优 调优概述 有的时候,我们可能会遇到大数据计算中一个最棘手的问题--数据倾斜,此时Spark作业的性能会比期望差很多.数据倾斜调优,就是使用各种技术方案解决不同类型的数据倾斜问题,以保证Spark作业的性能. 数据倾斜发生时的现象 绝大多数tas

&quot;WannaCry&quot;勒索病毒用户处置指南

"WannaCry"勒索病毒用户处置指南 原文: http://mp.weixin.qq.com/s/ExsribKum9-AN1ToT10Zog 前言:北京时间2017年5月12日晚,勒索软件"WannaCry"感染事件爆发,全球范围内99个国家遭到大规模网络攻击,被攻击者电脑中的文件被加密,被要求支付比特币以解密文件:众多行业受到影响,比如英国的NHS服务,导致至少40家医疗机构内网被攻陷,电脑被加密勒索:而我国众多行业也是如此,其中又以教育网最为显著,导致部分

servlet和jsp学习指南(一)servlet

近期接触了些纯servlet与jsp的编程项目,顺便把<servlet和jsp学习指南>这本书拿出来看看,感悟良多.记下随笔,以便会议. 要编写一个servlet首先要实现Servlet或者继承HttpServlet package test.com.servlet; import java.io.IOException; import javax.servlet.Servlet; import javax.servlet.ServletConfig; import javax.servlet

Quartz.NET简介及入门指南

Quartz.NET简介 Quartz.NET是一个功能完备的开源调度系统,从最小的应用到大规模的企业系统皆可适用. Quartz.NET是一个纯净的用C#语言编写的.NET类库,是对非常流行的JAVA开源调度框架 Quartz 的移植. 入门指南 本入门指南包括以下内容: 下载 Quartz.NET 安装 Quartz.NET 根据你的特定项目配置 Quartz 启动一个样例程序 下载和安装 你可以下载 zip 文件或使用 Nuget 程序包.Nuget 程序包只包含 Quartz.NET 运