gruntjs – browserify:连接的浏览器文件=>错误_prelude.js与加载单独的文件工作

连接两个浏览器化文件(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,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']
    },

解决方法

我做了一些初步调查,序言中似乎存在明确的问题.我已经提出了grunt-browserify维护者的问题,所以让我们看看是什么.

现在我将vendor.js和app.js之间的文件连接起来,作为修复前导码的方法,如下所示:

Gruntfile.js

concat: {
        'build/<%= pkg.name %>.js': ['build/vendor.js','client/src/fix_browserify',

fix_browserify

require=

请注意,上述文件中没有回车符或换行符

我不确定是否会有两次定义需求的意外后果,但它似乎在我的有限使用中起作用.如果您不仅仅有一个应用程序包,那么您同样需要在每个bundle之前交错fix_browserify文件的串联.

如果我发现任何更好的解决方案,我会更新这个答案.

UPDATE

在查看了browerify如何工作之后我最终放弃了grunt / browserify,只是选择了更容易设置的早午餐,并且当事情发生变化时也会更快地重建.虽然不是一个笨拙的替代品,但它构建了我需要的一切.

相关文章

这篇文章主要介绍“基于nodejs的ssh2怎么实现自动化部署”的...
本文小编为大家详细介绍“nodejs怎么实现目录不存在自动创建...
这篇“如何把nodejs数据传到前端”文章的知识点大部分人都不...
本文小编为大家详细介绍“nodejs如何实现定时删除文件”,内...
这篇文章主要讲解了“nodejs安装模块卡住不动怎么解决”,文...
今天小编给大家分享一下如何检测nodejs有没有安装成功的相关...