data:image/s3,"s3://crabby-images/f9239/f9239057920875a3e01c200fe17ccc83c6c8ab5a" alt="ASP.NET Core MVC 2.0 Cookbook"
How to do it...
- First, we add Gulp to package.json and the Gulp plugins. Then we need to minify and bundle these two JavaScript files if this file doesn't exist in the web application:
data:image/s3,"s3://crabby-images/06667/06667fa748c8a1cfc5ec817343a257829950fcfa" alt=""
- We add the gulp-concat plugin, which concatenates the (bundle) files, and then we add gulp-uglify, which minifies the .js files, removing whitespaces and comments, and writes the name of the module we want to add to the devDependencies section:
data:image/s3,"s3://crabby-images/2cded/2cdedb0ff26675849ab87d78f9dea518d01ebfbb" alt=""
- Let's create a gulpfile.js (a gulp configuration file):
- The generated file contains the following code:
data:image/s3,"s3://crabby-images/d7f05/d7f05718a47fc8254f137a6bf00bbadca9776f88" alt=""
- Let's add the following code in order to store the file paths for the files we will manipulate:
data:image/s3,"s3://crabby-images/6d744/6d7443347f5f0ca9fa929c2398a6105abd5c7175" alt=""
The path variable represents the wwwroot folder.
The path.js file represents all the JavaScript files in the wwwroot/js folder. path.minJs represents all the minified JavaScript files in the wwwroot/js folder that have a .min.js extension. path.concatJsDest represents the JavaScript file named site.min.js, which is the minification result of the two previous JavaScript file folders.
- Let's add the following code in order to create the task:
data:image/s3,"s3://crabby-images/4b98b/4b98be1b3c36dd664667b3c639b74a564780a614" alt=""
We require a Node.js function that will get the reference to a Gulp plugin or a Node module:
-
- gulp.task is a Gulp API that defines a task
- gulp.src is a Gulp API that reads a set of files
Inside gulp.task, we create all the tasks to be executed and rename default to min:js. We will chain the pipe functions to run these plugins in parallel:
-
- First, we save gulpfile.js
- Then, we refresh the task runner explorer
- Lastly, we run the task by right-clicking on the name of the task
The min:js gulp task exists now in the gulpfile task list:
data:image/s3,"s3://crabby-images/aefa0/aefa0fa0c31f647aa2757831d8578f8d2aaddb27" alt=""
We can look at the command line that is executed in the Output window:
data:image/s3,"s3://crabby-images/17b0a/17b0aea0e0732061d59397a312819ebeab1a4546" alt=""
The site.min.js file is now generated by the min:js task, which is the result of the minification and the concatenation of script1.js and script2.js:
data:image/s3,"s3://crabby-images/13a12/13a12d027461973ffc864e975d0a5a7bfbc03c79" alt=""