data:image/s3,"s3://crabby-images/f9239/f9239057920875a3e01c200fe17ccc83c6c8ab5a" alt="ASP.NET Core MVC 2.0 Cookbook"
上QQ阅读APP看书,第一时间看更新
How to do it...
We can use Grunt in two ways:
Without using Visual Studio, through the command line, using Command Prompt, Node.js, npm, and installing and using all the modules you need to execute all the tasks we want to run.
Installing Visual Studio 2015 Community Edition and the Visual Studio extensions that allow us to run these tasks in the Visual Studio user interface.
In this recipe, we will use Grunt in the second of these two ways, using Visual Studio to compile LESS files to CSS files:
- To install Grunt, let's open package.json, or if we begin from an empty project, just add a package.json file.
- Let's type grunt in the devDependencies section. IntelliSense will help us to find the Grunt package:
data:image/s3,"s3://crabby-images/a1a9b/a1a9bd3e3b65b87e78049acb5f80b8c1b5227b2b" alt=""
- After that, we type the version. IntelliSense will also help us to find the right Grunt version among all of the available versions. The grunt package will be downloaded automatically:
data:image/s3,"s3://crabby-images/35634/35634c7d3dad3c948875751e4bb3ac42d54c4c81" alt=""
Select the version of the package you wish to use.
data:image/s3,"s3://crabby-images/c28c7/c28c77e64b8e879ffedec609bb9baadcf153deea" alt=""
- We can also observe the new npm folder inside Dependencies, which contains the new Node module just installed, as well as all of its dependencies:
data:image/s3,"s3://crabby-images/f9f5d/f9f5d7d8dc76007c4af9cb7330ecbd72afd0c131" alt=""
- Let's create a .less file named site.less, selecting File | New item in the wwwroot/css folder:
data:image/s3,"s3://crabby-images/7091d/7091d3c65549c6fa0cff7b534294c541ab43cef4" alt=""
- Let's add two grunt packages:
- grunt-contrib-less to compile .less files to .css files.
- grunt-contrib-watch to automate this task, watching the modifications being made to a .less file in real time:
data:image/s3,"s3://crabby-images/b9c23/b9c23d0a91ec036c113407a67006a02cb5626c88" alt=""
- Let's create the Gruntfile.js by right-clicking on the application and choosing Add | New Item | DNX | client-side:
data:image/s3,"s3://crabby-images/aa65a/aa65a542eb1682daa01a2ef5c7a97cb454cde007" alt=""
- Let's add the following line of code to the initConfig method:
pkg: grunt.file.readJSON('package.json')
- Let's create the less task, which will compile a .less file into a .css file.
- We add the following code after grunt.config to be sure that our task uses the correct plugin:
grunt.loadNpmTasks('grunt-contrib-less');
- We will then add the following code to register this task as the default grunt task:
grunt.registerTask('default', ['less']);
Let's refresh the gruntfile.js:
data:image/s3,"s3://crabby-images/bb2d7/bb2d739d4c4ff10640f472f9f9d6a910daa4feac" alt=""
- After refreshing the gruntfile.js, we can see the .less task just created:
data:image/s3,"s3://crabby-images/4ee54/4ee547d6a86d94936366ebf3beb59e39f5cb0ce4" alt=""
- Let's now run the task by right-clicking on the name of the task in Task Runner Explorer:
data:image/s3,"s3://crabby-images/2599b/2599b2e9c0d564132714479ba88d0ec6b0fe6940" alt=""
We can see the command line that is generated by Visual Studio:
Now we can also see that the .css file is generated:
data:image/s3,"s3://crabby-images/036d4/036d422ed392de3b946a6c83e63221dcec4701c2" alt=""
We can see the .css code has been generated as well:
data:image/s3,"s3://crabby-images/a8124/a81242a04d73e0ad1ef19f6b82b1c189c7e03e31" alt=""