Concat and minify JS files in Node Concat and minify JS files in Node javascript javascript

Concat and minify JS files in Node


I recommend using UglifyJS which is a JavaScript parser / mangler / compressor / beautifier library for NodeJS.

If you are interested in automation tools that do more than simply concatenate and minify files, there are the following solutions:

  • GruntJS is a task-based command line build tool for JavaScript projects. The current version has the following built-in tasks:

    1. concat - Concatenate files.
    2. init - Generate project scaffolding from a predefined template.
    3. lint - Validate files with JSHint.
    4. min - Minify files with UglifyJS.
    5. qunit - Run QUnit unit tests in a headless PhantomJS instance.
    6. server - Start a static web server.

Besides this tasks there's a lot of plugins available.

  • Gulp is a toolkit that will help you automate painful or time-consuming tasks in your development workflow. For web development (if that's your thing) it can help you by doing CSS preprocessing, JS transpiling, minification, live reloading, and much more. Integrations are built into all major IDEs and people are loving gulp across PHP, .NET, Node.js, Java, and more. With over 1700 plugins (and plenty you can do without plugins), gulp let's you quit messing with build systems and get back to work.

  • Yeoman is a robust and opinionated set of tools, libraries, and a workflow that can help developers quickly build beautiful, compelling web apps.

    1. Lightning-fast scaffolding - Easily scaffold new projects with customizable templates (e.g HTML5 Boilerplate, Twitter Bootstrap), AMD (via RequireJS) and more.
    2. Automatically compile CoffeeScript & Compass - Our LiveReload watch process automatically compiles source files and refreshes your browser whenever a change is made so you don't have to.
    3. Automatically lint your scripts - All your scripts are automatically run against jshint to ensure they're following language best-practices.
    4. Built-in preview server - No more having to fire up your own HTTP Server. My built-in one can be fired with just one command.
    5. Awesome Image Optimization - I optimize all your images using OptiPNG and JPEGTran so your users can spend less time downloading assets and more time using your app.
    6. AppCache manifest generation - I generate your application cache manifests for you. Just build a project and boom. You'll get it for free.
    7. Killer build process - Not only do you get minification and concatenation; I also optimize all your image files, HTML, compile your CoffeeScript and Compass files, generate you an application cache manifest and, if you're using AMD, we'll pass those modules through r.js so you don't have to.
    8. Integrated package management - Need a dependency? It's just a keystroke away. I allow you to easily search for new packages via the command-line (e.g., yeoman search jquery), install them and keep them updated without needing to open your browser.
    9. Support for ES6 module syntax - Experiment with writing modules using the latest ECMAScript 6 module syntax. This is an experimental feature that transpiles back to ES5 so you can use the code in all modern browsers.
    10. PhantomJS Unit Testing - Easily run your unit tests in headless WebKit via PhantomJS. When you create a new application, I also include some test scaffolding for your app.


UglifyJS is a Node module that is all about minifying javascript. I don't think it also joins files, but there might be an option I missed.

Edit:With UglifyJS 2, it has built in concatenation as well.

If you want to do this inline in your node app it's really easy. This allows you to dynamically generate your minified/concatenated js script at runtime without using the grunt or yeoman way.

npm install uglify-js

and in your module:

var fs = require('fs');var uglify = require("uglify-js");var uglified = uglify.minify(['file1.js', 'file2.js', 'file3.js']);fs.writeFile('concat.min.js', uglified.code, function (err){  if(err) {    console.log(err);  } else {    console.log("Script generated and saved:", 'concat.min.js');  }      });


If you're using Connect, then I've had good luck with Connect-Assetmanager