1

これは私の関連部分ですindex.html

<!-- build:js scripts/scripts.js -->
<script src="scripts/vendor/jquery.js"></script>
<script src="scripts/vendor/bootstrap.min.js"></script>
<script src="scripts/vendor/handlebars.runtime.js"></script>
<script src="scripts/vendor/ember.js"></script>
<script src="scripts/vendor/ember-data.js"></script>
<script src="scripts/templates.js"></script>
<script src="scripts/neuterapp.js"></script>
<!-- endbuild -->

(しかし、最後の2つのエントリは間違っています。それは実際には私の問題です)

これは、次の関連部分ですGruntfile.js

    useminPrepare: {
        html: '<%= yeoman.app %>/index.html',
        options: {
            dest: '<%= yeoman.dist %>'
        }
    },
    usemin: {
        html: ['<%= yeoman.dist %>/*.html'],
        css: ['<%= yeoman.dist %>/styles/*.css'],
        options: {
            dirs: ['<%= yeoman.dist %>']
        }
    },

私が抱えている問題は、 と の両方templates.jsneuterapp.js生成されたファイルであるため、<%= yeoman.app %>/scriptsではなく<%= yeoman.dist %>/scripts.

これは私の(単純化された)ディレクトリ構造です:

webapp/
├── app
│   ├── app.js <--- for neuter
│   ├── controllers
│   ├── index.html
│   ├── models
│   ├── routes
│   ├── scripts
│   │   └── vendor <--- for usemin
│   ├── templates <--- for ember_templates
│   │   ├── template1.hbs
│   │   └── template2.hbs
│   └── views
├── dist
│   ├── index.html
│   └── scripts
│       ├── neuterapp.js <--- this must also be used for usemin!!!
│       └── templates.js <--- this must also be used for usemin!!!
└── Gruntfile.js

usemin生成されたファイルを含めるように指示するにはどうすればよいですか?

これが必要な場合に備えて、これらは と の構成neuterですember_templates

    neuter: {
        options: {
            includeSourceURL: true
        },
        '<%= yeoman.dist %>/scripts/neuterapp.js': '<%= yeoman.app %>/app.js'
    },
    ember_templates: {
        compile: {
            options: {
                templateName: function (sourceFile) {
                    return sourceFile.replace(/app\/templates\//, ''); // <%= yeoman.dist %>/scripts/
                }
            },
            files: {
                '<%= yeoman.dist %>/scripts/templates.js': [
                    '<%= yeoman.app %>/templates/**/*.hbs'
                ]
            }
        }
    },
4

1 に答える 1

2

copy タスクを使用して、一時的な場所で usemin が必要とするものを準備できます。

私があなたに提案すること:

  • 必要なアプリファイルをアプリから一時にコピーします
  • ファイルを生成するタスクがtempに出力できるようにします
  • usemin&useminPrepareタスクを一時的に実行し、 distに出力します。
于 2013-04-10T12:52:01.053 に答える