在browserify之后无法在浏览器中调用函数:未捕获的ReferenceError

时间:2017-11-28 22:17:48

标签: javascript node.js npm browserify

我正在开发一个小型NPM包。这是一个基本原型:

function foo() {
  return 'foo';
}

module.exports = foo;

此模块也可在浏览器中使用。所以我安装了browserify并运行了这个命令:

browserify foo.js -o foo_bundle.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){
function foo() {
  return 'foo';
}

module.exports = foo;
},{}]},{},[1]);

示例HTML文档:

<html>
  <head>
    <script src="foo_bundle.js"></script>
  </head>
  <body>
    <div id="myElement"></div>
    <script type="text/javascript">
      var element = document.getElementById("myElement");
      element.innerHTML = foo();
    </script>    
  </body>
</html>

我原本希望将字符串foo写入div元素,而不是浏览器的JavaScript控制台:

foo.html:9 Uncaught ReferenceError: foo is not defined

我在这里缺少什么?

1 个答案:

答案 0 :(得分:1)

您需要将其捆绑为独立版本(UMD)以在浏览器中使用:

browserify foo.js -o foo_bundle.js -s foo

更多用法here