簡體   English   中英

為每個模塊發出咕unt聲,然后最小化

[英]Grunt concat for each module then minify

嘗試用Grunt做到這一點。 我有一個像這樣的文件結構:

/app
--app.js
--/module1
----module1.js
----module1Model.js
--/module2
----module2.js
----module2Model.js

如何將每個模塊串聯並縮小到一個文件中,使其看起來像:

/app
--app.min.js
--module1.min.js
--module2.min.js

我們希望它具有可伸縮性,因此當我們添加module3,4時它仍然可以工作。 謝謝您的幫助!

您可以使用uglify作為解決方案,並且可以根據用途更改“ dist”和“ src”:

uglify:{
        liveproject:{
            files:{
                'dist/js/main.min.js' : ['src/js/*.js'],
                'dist/js/m1.min.js' : ['src/js/easing.js','src/js/modernizer.js'],
            }   

        }

    },

我從這篇文章中得出了我的答案: 使用grunt將來自許多目錄的許多文件合並為新目錄中的單個重命名文件

grunt.registerTask('prepareModule', 'process dist module for concat', function() {

        //get configured concat task object
        var concat = grunt.config.get('concat') || {};

        //iterate through all file/folders at build/src/app/
        grunt.file.expand(grunt.config('build_dir') + '/src/app/*').forEach(function(dir) {

            //grab the last path name
            var dirName = dir.substr(dir.lastIndexOf('/') + 1);

            //filter for folders only
            if (dirName.slice(-3) !== '.js') {

                //add target for each module
                concat[dirName] = {
                    src: [grunt.config('build_dir') + '/src/app/' + dirName + '/*.js'],
                    dest: grunt.config('dist_dir') + '/src/app/' + dirName + '/' + dirName + '.js'
                };
            }
        });

        grunt.config.set('concat', concat);

    });

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM