过滤变量和为Node.js构建缩小的JS分布工件的策略

时间:2013-08-28 16:52:40

标签: javascript node.js gruntjs

我来自Java / Maven背景,您可以在其中创建要部署的WAR文件。 Maven提供了在构建期间“过滤”文件的能力,并在构建时将变量替换为您正在部署的环境的目标信息。

现在我在Node.js工作,我想知道是否有类似的设施和最佳实践,您可以在Node.js中使用,我可以将我的javascript缩小为单个文件但同时过滤相应的变量我正在部署的环境。

例如,有一个app_name配置,我想要特定于环境:

  exports.config = {
     app_name : ['$APPNAME-$ENV'],
     license_key : 'xxx',
     logging : {
       level : '$DEBUG_LEVEL'
     }
  };

所以我希望能够将上面带有环境特定变量的所有$变量更新到一个单独的缩小的JS文件中。好像我必须将文件复制到临时区域,对变量进行字符串替换然后缩小。这看起来是否合理,或者是否有关于如何在Node世界中最好地完成此任务的建议?

1 个答案:

答案 0 :(得分:1)

以下是我最终使用GruntJS完成上述内容(清理,复制,字符串替换,JSHint和Google CC缩小)的内容。对于那些对深度潜水感兴趣的人,我发布了更完整的here读物。

(function () {
    'use strict';
    module.exports = function (grunt) {
        grunt.initConfig({
            pkg: grunt.file.readJSON('package.json'),
            clean: ["dist"],
            copy: {
                build: {
                    files: [
                        {src: ['./**/*.js', './*.json', './stackato.yml', './README.md', './nunit.js', './test/**/*', '!./dist/**/*', '!./node_modules/**/*', '!./Gruntfile.js'], dest: 'dist/'}
                    ]
                }
            },
            'string-replace': {
                dev: {
                    files: {
                        "dist/": ["newrelic.js", "stackato.yml", "package.json"]
                    },
                    options: {
                        replacements: [
                            {
                                pattern: '$APPNAME',
                                replacement: "services-people"
                            },
                            {
                                pattern: '$VERSION',
                                replacement: "1.0.6"
                            },
                            {
                                pattern: 'server.js',
                                replacement: "server.min.js"
                            },
                            {
                                pattern: '$ENV',
                                replacement: "DEV"
                            },
                            {
                                pattern: '$PDS_PWD',
                                replacement: ""
                            },
                            {
                                pattern: '$INSTANCES',
                                replacement: "1"
                            },
                            {
                                pattern: '$NEWRELIC_TRACE_LVL',
                                replacement: "trace"
                            }
                        ]
                    }
                },
                prod: {
                    files: {
                        "dist/": ["newrelic.js", "stackato.yml", "package.json"]
                    },
                    options: {
                        replacements: [
                            {
                                pattern: '$APPNAME',
                                replacement: "services-people"
                            },
                            {
                                pattern: '$VERSION',
                                replacement: "1.0.6"
                            },
                            {
                                pattern: 'server.js',
                                replacement: "server.min.js"
                            },
                            {
                                pattern: '$ENV',
                                replacement: "prod"
                            },
                            {
                                pattern: '$PDS_PWD',
                                replacement: ""
                            },
                            {
                                pattern: '$INSTANCES',
                                replacement: "2"
                            },
                            {
                                pattern: '$NEWRELIC_TRACE_LVL',
                                replacement: "info"
                            }
                        ]
                    }
                }
            },
            jshint: {
                options: {
                    curly: true,
                    eqeqeq: true,
                    eqnull: true,
                    strict: true,
                    globals: {
                        jQuery: true
                    },
                    ignores: ['dist/test/**/*.js']
                },
                files: ['Gruntfile.js', 'dist/**/*.js']
            },
            nodeunit: {
              all: ['dist/test/*-tests.js']
            },
            'closure-compiler': {
                build: {
                    closurePath: '.',
                    js: 'dist/**/*.js',
                    jsOutputFile: 'dist/server.min.js',
                    maxBuffer: 500,
                    options: {
                        compilation_level: 'ADVANCED_OPTIMIZATIONS',
                        language_in: 'ECMASCRIPT5_STRICT',
                        debug: false
//                        formatting: 'PRETTY_PRINT'
                    }
                }
            }
        });

        grunt.loadNpmTasks('grunt-closure-compiler');
        grunt.loadNpmTasks('grunt-contrib-copy');
        grunt.loadNpmTasks('grunt-contrib-clean');
        grunt.loadNpmTasks('grunt-contrib-jshint');
        grunt.loadNpmTasks('grunt-contrib-nodeunit');
        grunt.loadNpmTasks('grunt-string-replace');

        // Default task(s).
        grunt.registerTask('default', ['clean', 'copy:build', 'string-replace:dev', 'jshint', 'closure-compiler:build']);
        grunt.registerTask('prod', ['clean', 'copy:build', 'string-replace:prod', 'jshint', 'closure-compiler:build']);
    };
})();

在CLI上,您可以使用“grunt”来启动DEV版本或“grunt prod”来构建PROD版本。