Node.JS实战29:在浏览器端使用Node模块。

正常理解来说,Node.JS是应用于服务端、后端的。

但是,知道吗?NodeJS中编写的代码,也是能运行于客户端(前端)的,包括require()方法组织的代码。

要实现这一点,需要借助于三方模块:Browserify(http://browserify.org/)

Browserify

Browserify是一个将NodeJS代码进行打包,以使之能在浏览器环境使用打包工具。

看一个简单的例程:

main.js代码:

var abc = require('./abc.js');
document.getElementById('result').innerHTML = abc(100,200);

abc.js代码:

module.exports = function abc(a,b){
    return a+b;
}

这样的两个文件代码,显然是无法在浏览器中运行的,但如果经Browserify,则会变的可以。

再准备一个文件:browserify.js

var browserify = require("browserify");

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

准备好这三个文件,就可以进行本例的打包了:

1、首先安装browserify模块:

2、node browserify进行打包:

可以看到,打包后输出了打包代码,因为上文我们是通过process.stdout输出到命令行的。

可以这样运行,将结果输出到budle.js文件:

node browserify > budle.js

文件打包完成。

验证一下,是否可以在浏览器端运行,注意,要有一个id为result的div元素,以及要引入budle.js文件:

<html>
    <body>
        <div id = "result"></div>
    </body>
    <script src="budle.js"></script>
</html>

可以看到,网页中显示300,正是我们前面nodejs程序的运算结果。

示例显示经browserify打包,程序确实运行在浏览器中了。

browserify的另一种用法

上面,我们是通过调用代码调用browserify模块实现的打包。

如果将browserify通过全局安装,使用命令打包则会更方便些:

 

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值