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/c03ba/c03ba963c336c0985aab12799a42e25e76641e49" 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/e7615/e7615639ab72602a17438cb10705c30e6b0a8ab3" alt=""
- Let's create a gulpfile.js (a gulp configuration file):
- The generated file contains the following code:
data:image/s3,"s3://crabby-images/4bf59/4bf591d7259da76b6411d941ad343bebc5916eae" 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/117ee/117ee180c15ee960640dd7d54646d6e17b1dcf20" 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/b094d/b094d57fd88b185b56065eb5674066d0ed151f3a" 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/9b481/9b481c2fb1db72d9860ab23dd3317d611193297c" alt=""
We can look at the command line that is executed in the Output window:
data:image/s3,"s3://crabby-images/0139f/0139f643f75622781cc87044cd3ba9fd16dad857" 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/b3a6b/b3a6b2416986ba28a3899ec94a2ed0396eccc2b2" alt=""