早午餐:如何在AMD模块中包装供应商代码?

时间:2015-04-28 13:08:45

标签: javascript brunch

我希望所有供应商代码都包含在AMD模块中。 我在config.coffee中定义了这一部分:

modules:
    wrapper: 'amd'
    definition: 'amd'

但似乎早午餐仅将“AMD优化器”用于“app”文件夹文件。所有供应商js文件在哪里连接,没有任何类似r.js的预处理(在“define(...)”语句中没有添加模块名称)。因此,Almond(它与RequireJS几乎相同)在供应商文件执行期间抱怨匿名模块定义。

这是我的完整配置:

exports.config =

  paths:
    public: 'public'

  files:
    javascripts:
      defaultExtension: 'js'

      joinTo:
        'js/app.js': /^app/
        'js/vendor.js': /^vendor[\\/](?!mocha|chai|sinon|sinon-chai)/
        'js/tests.js': /^test/
        'js/tests-vendor.js': /^vendor[\\/](?=mocha|chai|sinon|sinon-chai)/

      order:
        before: [
          'bower_components/almond/almond.js',
          'bower_components/jquery/jquery.js',
          'bower_components/lodash/dist/lodash.underscore.js'
        ]

    stylesheets:
      defaltExtension: 'less'

      joinTo:
        'css/styles.css': /^(vendor[\\/](?!mocha|chai|sinon|sinon-chai)|app)/
        'css/tests-vendor.css': /^(vendor[\\/](?=mocha|chai|sinon|sinon-chai))/

    templates:
      defaultExtension: 'hbs'
      joinTo: 'js/app.js'

  modules:
    wrapper: 'amd'
    definition: 'amd'

1 个答案:

答案 0 :(得分:0)

您可以将配置中的conventions.vendor更改为与您的供应商文件不匹配的内容,以启用模块包装。

https://github.com/brunch/brunch/blob/master/docs/config.md#conventions