javascript - 捆绑订单如何在 browserify 中工作?

标签 javascript browserify

我无法弄清楚 browserify 如何捆绑其所需文件的逻辑。如果我这样做

require('./one/one.js');
require('./two/two.js');
require('./three/three.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);throw new Error("Cannot find module '"+o+"'")}var f=n[o]={exports:{}};t[o][0].call(f.exports,function(e){var n=t[o][1][e];return s(n?n:e)},f,f.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 app = "app";

console.log(one);
},{}],2:[function(require,module,exports){
require('./one/one.js');
require('./two/two.js');
require('./three/three.js');
//require('./three/three_a/three_a.js');
require('./app.js');
},{"./app.js":1,"./one/one.js":3,"./three/three.js":4,"./two/two.js":5}],3:[function(require,module,exports){
var one = "one";
},{}],4:[function(require,module,exports){
var three = "three";
},{}],5:[function(require,module,exports){
var two = "two";
},{}]},{},[2])

如您所见,“三”在“二”之前捆绑,但这不是我要求的顺序?

最佳答案

看起来是按字母顺序排列的。也许 Browserify 以这种方式对它们进行排序,或者这就是它来自操作系统的方式。这并没有什么区别——那些只是模块定义。在那些 (require, module, exports) 函数中,无论模块的定义顺序如何,您的代码将始终以相同的方式运行。

这是 Browserify 正在做的事情的简化版本,可能更清楚:

var modules = {
  './app.js': function (require, module, exports) {
    require('./one/one.js');
    require('./two/two.js');
    require('./three/three.js');
  },
  './two/two.js': function (require, module, exports) {
    console.log('two');
  },
  './one/one.js': function (require, module, exports) {
    console.log('one');
  },
  './three/three.js': function (require, module, exports) {
    console.log('three');
  }
};

function require (path) {
  var module = {exports: {}};
  modules[path](require, module, module.exports);
  return module.exports;
}

require('./app.js');

即使您更改模块的定义顺序,您也应该始终看到相同的输出:

one
two
three

关于javascript - 捆绑订单如何在 browserify 中工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23239296/

相关文章:

javascript - 用 css 或 javascript 将文本包装在固定的 Div 中?

javascript - 隐藏特定时间的YouTube API元素

javascript - 如何在浏览器中动态创建javascript文件

javascript - Typescript 和 Browserify - 未捕获的 TypeError : Cannot read property 'step' of undefined

javascript - babel,browserify 错误 : using removed babel 5 option base. 阶段

javascript - 打开/关闭后解决方案消失响应式导航

javascript - setTimeout 如何工作?

javascript - for 循环中的函数。只有最后一个元素受到影响

javascript - 无法使 libphonenumber npm 包正常工作,fs.readFileSync 不是函数错误

javascript - 需要模式 Browserify/Angular