zoukankan      html  css  js  c++  java
  • 使用Browserify来实现CommonJS的浏览器加载

    前面的话

      Nodejs的模块是基于CommonJS规范实现的,可不可以应用在浏览器环境中呢?

    var math = require('math');
    math.add(2, 3);

      第二行math.add(2, 3),在第一行require('math')之后运行,因此必须等math.js加载完成。也就是说,如果加载时间很长,整个应用就会停在那里等。这对服务器端不是一个问题,因为所有的模块都存放在本地硬盘,可以同步加载完成,等待时间就是硬盘的读取时间。但是,对于浏览器,这却是一个大问题,因为模块都放在服务器端,等待时间取决于网速的快慢,可能要等很长时间,浏览器处于"假死"状态

      而browserify这样的一个工具,可以把nodejs的模块编译成浏览器可用的模块,解决上面提到的问题。本文将详细介绍Browserify

    实现

      Browserify是目前最常用的CommonJS格式转换的工具

      请看一个例子,b.js模块加载a.js模块

    // a.js
    var a = 100;
    module.exports.a = a;
    
    // b.js
    var result = require('./a');
    console.log(result.a);

      index.html直接引用b.js会报错,提示require没有被定义

    //index.html
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
    </head>
    <body>
    <script src="b.js"></script>    
    </body>
    </html>

     

      这时,就要使用Browserify了

    【安装】

      使用下列命令安装browserify

    npm install -g browserify

    【转换】

      使用下面的命令,就能将b.js转为浏览器可用的格式bb.js

    $ browserify b.js > bb.js

      查看bb.js,browserify将a.js和b.js这两个文件打包为bb.js,使其在浏览器端可以运行

    (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
    var a = 100;
    module.exports.a = a;
    },{}],2:[function(require,module,exports){
    var result = require('./a');
    console.log(result.a);
    },{"./a":1}]},{},[2]);

      index.html引用bb.js,控制台显示100

    //index.html
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
    </head>
    <body>
    <script src="bb.js"></script>    
    </body>
    </html>

    原理

      Browserify到底做了什么?安装一下browser-unpack,就能清楚原理了

    $ npm install browser-unpack -g

      然后,使用下列命令,将前面生成的bb.js解包

    $ browser-unpack < bb.js

      可以看到,browerify将所有模块放入一个数组,id属性是模块的编号,source属性是模块的源码,deps属性是模块的依赖

      因为b.js里面加载了a.js,所以deps属性就指定./a对应1号模块。执行的时候,浏览器遇到require('./a')语句,就自动执行1号模块的source属性,并将执行后的module.exports属性值输出

      browerify将a.js和b.js打包,并生成bb.js,browser-unpack将bb.js解包,是一个逆向的过程。但实际上,bb.js依然存在

  • 相关阅读:
    [Python] Calculate pi With MonteCarlo
    二次函数闭区间求最小值、、
    [2013.10.30 Luogu OJ P1509]找啊找啊找GF
    IE8下绝对居中的margin:auto兼容问题解决办法
    上传文件过长中间显示省略号
    全选
    往textarea中光标所在位置插入文本
    侧栏悬浮窗
    IE火狐兼容小知识点(即时更新)
    排序、添加、删除、上移、下移功能
  • 原文地址:https://www.cnblogs.com/xiaohuochai/p/6850977.html
Copyright © 2011-2022 走看看