4

次のディレクトリ構造があります(関連するビットのみ):

app
 - build
   - script.js
 - js
   - lib
     - require.js
     - jquery-1.10.2.js
   - app.js
 - index.html
Gruntfile.js

Gruntfile.js には以下が含まれます。

module.exports = function (grunt) {

    var gruntConfig = {
        pkg: grunt.file.readJSON('package.json'),
        requirejs: {
            compile: {
                options: {
                    name: 'app',
                    baseUrl: 'app/assets/js',
                    out: 'app/assets/build/script.js',
                    include:  ['lib/require'],

                    uglify: {
                        // beautify: true,
                        defines: {
                            DEBUG: ['name', 'false']
                        }
                    },

                    paths: {
                        jquery: "lib/jquery-1.10.2"
                    }
                }
            }
        },
    };

    grunt.initConfig(gruntConfig);

    grunt.loadNpmTasks('grunt-contrib-requirejs');

};

app.js には以下が含まれます。

require(['jquery'], function ($) {
    // Do stuff
});

指示したときに app.js と require.js だけでなく、必要なすべての JavaScript を build/script.jsにコピーするように設定するにはどうすればよいですか(jQuery を使用しようとするとエラーが発生します)。また、モジュールを Gruntfile に追加せずに、script.js に追加するだけでモジュールを追加できるようにしたいと考えています。

4

2 に答える 2

1

mainConfigFile を定義し、構成ファイル内にこのような lib コードへのパスを含めることができます

gruntfile の内容:

requirejs: {
  compile: {
    options: {
      baseUrl: "app/js/",
      mainConfigFile: app/config.js",
      out: "build/script.js",
      name: "config"
    }
  }
}

設定ファイルの内容:

require.config({
  paths: {
    lib: "<path to>/js/lib",
    jquery: "<path to>/js/lib/jquery-1.10.2.min",
    .
    and particular file required
    .
  }

Requirejs は、すべてのパス ファイルの内容を最適化されたコードに追加します。

于 2014-01-03T08:26:49.657 に答える