将两个浏览器化文件(vendor.js和app.js连接到combined.js)时遇到问题
在浏览器中加载combined.js会在_prelude.js中抛出以下内容:
Uncaught Error: Cannot find module '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}'
单独加载浏览器化文件时效果很好。
我缺少什么?
(如果您需要更多配置,请告诉我,很高兴提供)
感谢您的帮助!
在Gruntfile.js中:
browserify: {
vendor: {
src: ['client/requires/**/*.js'],
dest: 'build/vendor.js',
options: {
shim: {
jquery: {
path: 'client/requires/jquery/js/jquery.js',
exports: '$'
},
underscore: {
path: 'client/requires/underscore/js/underscore.js',
exports: '_'
},
backbone: {
path: 'client/requires/backbone/js/backbone.js',
exports: 'Backbone',
depends: {
underscore: 'underscore'
}
},
'backbone.marionette': {
path: 'client/requires/backbone.marionette/js/backbone.marionette.js',
exports: 'Marionette',
depends: {
jquery: '$',
backbone: 'Backbone',
underscore: '_'
}
},
eventsource: {
path: 'client/requires/eventsource/eventsource.js',
exports: 'EventSource'
},
moment: {
path: 'client/requires/moment/moment.js',
exports: 'moment'
},
bootstrap: {
path: 'client/requires/bootstrap/js/bootstrap.js',
exports: null
}
}
}
},
app: {
files: {
'build/app.js': ['client/src/main.js']
},
options: {
transform: ['node-underscorify'],
debug: true,
external: ['jquery', 'underscore', 'backbone', 'backbone.marionette', 'eventsource', 'moment', 'bootstrap']
}
},
},
concat: {
'build/<%= pkg.name %>.js': ['build/vendor.js', 'build/app.js']
},
答案 0 :(得分:2)
我做了一些初步调查,前言似乎有一定的问题。我已经提出了grunt-browserify维护者的问题,所以让我们看看是什么来的。
目前我正在连接vendor.js和app.js之间的文件,作为修复序言的方法如下:
<强> Gruntfile.js 强>
concat: {
'build/<%= pkg.name %>.js': ['build/vendor.js', 'client/src/fix_browserify', 'build/app.js']
},
<强> fix_browserify 强>
require=
请注意,上述文件中没有回车符或换行符
我不确定两次定义require
是否会产生任何意想不到的后果,但它似乎在我的有限使用中起作用。如果您只有一个应用程序包,那么您同样需要在每个捆绑包之前交错fix_browserify
文件的串联。
如果我发现任何更好的解决方案,我会更新这个答案。
<强>更新强>
在查看了browerify如何工作之后我最终放弃了grunt / browserify,只是选择了更容易设置的早午餐,并且当事情发生变化时也会更快地重建。虽然不是一个笨拙的替代品,但它构建了我需要的一切。
答案 1 :(得分:2)
我们通过确保在连接之前确保每个文件中的JS包以分号结尾(如Keven Wang mentioned)来修复此错误。
看起来像写作一样,如果您启用了生成源地图(由debug
选项控制),Browserify将省略分号(可能由于this issue) 。如果我们不提供此选项,Browserify会添加分号,并且连接后没有错误。
似乎存在由默认行为导致的问题 - 省略或附加分号(参见this issue - 有时你想将输出包装在表达式中,所以不要半结肠)。它在很大程度上依赖于你的构建管道,因为我们在另一个项目中没有错误,这个项目的构建过程略有不同,通过Grunt的uglify
任务运行输出,剥离源映射,并在端。
我认为安德鲁添加间隔文件的解决方案是不必要的hacky,并且有更好的解决方案可用于确保输出符合您的预期(即在结尾处使用分号)。