我是靠谱客的博主 大气太阳,这篇文章主要介绍grunt常用模块,现在分享给大家,希望可以做个参考。

grunt.initConfig方法

用于模块配置,它接受一个对象作为参数。该对象的成员与使用的同名模块一一对应。

每个目标的具体设置,需要参考该模板的文档。就cssmin来讲,minify目标的参数具体含义如下:

  • expand:如果设为true,就表示下面文件名的占位符(即*号)都要扩展成具体的文件名。
  • cwd:需要处理的文件(input)所在的目录。
  • src:表示需要处理的文件。如果采用数组形式,数组的每一项就是一个文件名,可以使用通配符。
  • dest:表示处理后的文件名或所在目录。
  • ext:表示处理后的文件后缀名。

 

grunt常用函数说明:

grunt.initConfig:定义各种模块的参数,每一个成员项对应一个同名模块。
grunt.loadNpmTasks:加载完成任务所需的模块。
grunt.registerTask:定义具体的任务。第一个参数为任务名,第二个参数是一个数组, 表示该任务需要依次使用的模块。

 

grunt常用模块:

  • grunt-contrib-clean:删除文件。
  • grunt-contrib-compass:使用compass编译sass文件。
  • grunt-contrib-concat:合并文件。
  • grunt-contrib-copy:复制文件。
  • grunt-contrib-cssmin:压缩以及合并CSS文件。
  • grunt-contrib-imagemin:图像压缩模块。
  • grunt-contrib-jshint:检查JavaScript语法。
  • grunt-contrib-uglify:压缩以及合并JavaScript文件。
  • grunt-contrib-watch:监视文件变动,做出相应动作。

 

package.json 包依赖关系:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
{
   "name" : "grunt-study" ,
   "version" : "1.0.0" ,
   "description" : "study" ,
   "main" : "index.js" ,
   "scripts" : {
     "test" : "test"
   },
   "repository" : {
     "type" : "git" ,
     "url" : "https://github.com/hubcarl"
   },
   "devDependencies" :{
     "matchdep" : "latest" ,
     "shelljs" : "latest" ,
     "ngmshell" : "latest" ,
     "grunt" : "latest" ,
     "grunt-contrib-clean" : "latest" ,
     "grunt-contrib-concat" : "latest" ,
     "grunt-contrib-copy" : "latest" ,
     "grunt-contrib-connect" : "latest" ,
     "grunt-contrib-htmlmin" : "latest" ,
     "grunt-contrib-cssmin" : "latest" ,
     "grunt-contrib-imagemin" : "latest" ,
     "grunt-contrib-uglify" : "latest" ,
     "grunt-contrib-watch" : "latest" ,
     "grunt-usemin" : "latest" ,
     "connect-livereload" : "latest"
   },
   "keywords" : [
     "grunt"
   ],
   "author" : "bluesky" ,
   "license" : "BSD-2-Clause" ,
   "bugs" : {
     "url" : "https://github.com/hubcarl"
   }
}

  

Gruntfile.js配置css、image、javascript、html压缩

复制代码
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
1 module.exports = function (grunt) { 2 3 require('matchdep').filterDev('grunt-*').forEach(grunt.loadNpmTasks); 4 5 grunt.initConfig({ 6 7 //清除目录 8 clean: { 9 all: ['dist/html/**', 'dist/*.*'], 10 image: 'dist/html/images', 11 css: 'dist/html/css', 12 html: 'dist/html/**/*' 13 }, 14 15 copy: { 16 src: { 17 files: [ 18 {expand: true, cwd: 'src', src: ['*.html'], dest: 'dist/html'} 19 ] 20 }, 21 image: { 22 files: [ 23 {expand: true, cwd: 'src', src: ['images/*.{png,jpg,jpeg,gif}'], dest: 'dist/html'} 24 ] 25 } 26 }, 27 28 // 文件合并 29 concat: { 30 options: { 31 separator: ';', 32 stripBanners: true 33 }, 34 js: { 35 src: [ 36 "src/js/*.js" 37 ], 38 dest: "dist/html/js/app.js" 39 }, 40 css:{ 41 src: [ 42 "src/css/*.css" 43 ], 44 dest: "dist/html/css/main.css" 45 } 46 }, 47 48 //压缩JS 49 uglify: { 50 prod: { 51 options: { 52 mangle: { 53 except: ['require', 'exports', 'module', 'window'] 54 }, 55 compress: { 56 global_defs: { 57 PROD: true 58 }, 59 dead_code: true, 60 pure_funcs: [ 61 "console.log", 62 "console.info" 63 ] 64 } 65 }, 66 67 files: [{ 68 expand: true, 69 cwd: 'dist/html', 70 src: ['js/*.js', '!js/*.min.js'], 71 dest: 'dist/html' 72 }] 73 } 74 }, 75 76 //压缩CSS 77 cssmin: { 78 prod: { 79 options: { 80 report: 'gzip' 81 }, 82 files: [ 83 { 84 expand: true, 85 cwd: 'dist/html', 86 src: ['css/*.css'], 87 dest: 'dist/html' 88 } 89 ] 90 } 91 }, 92 93 //压缩图片 94 imagemin: { 95 prod: { 96 options: { 97 optimizationLevel: 7, 98 pngquant: true 99 }, 100 files: [ 101 {expand: true, cwd: 'dist/html', src: ['images/*.{png,jpg,jpeg,gif,webp,svg}'], dest: 'dist/html'} 102 ] 103 } 104 }, 105 106 // 处理html中css、js 引入合并问题 107 usemin: { 108 html: 'dist/html/*.html' 109 }, 110 111 //压缩HTML 112 htmlmin: { 113 options: { 114 removeComments: true, 115 removeCommentsFromCDATA: true, 116 collapseWhitespace: true, 117 collapseBooleanAttributes: true, 118 removeAttributeQuotes: true, 119 removeRedundantAttributes: true, 120 useShortDoctype: true, 121 removeEmptyAttributes: true, 122 removeOptionalTags: true 123 }, 124 html: { 125 files: [ 126 {expand: true, cwd: 'dist/html', src: ['*.html'], dest: 'dist/html'} 127 ] 128 } 129 } 130 131 }); 132 133 134 grunt.registerTask('prod', [ 135 'copy', //复制文件 136 'concat', //合并文件 137 'imagemin', //图片压缩 138 'cssmin', //CSS压缩 139 'uglify', //JS压缩 140 'usemin', //HTML处理 141 'htmlmin' //HTML压缩 142 ]); 143 144 grunt.registerTask('publish', ['clean', 'prod']); 145 };
复制代码

index.html发布之前内容:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<! DOCTYPE  html>
< html >
< head >
     < title >Grunt 测试</ title >
     < meta  charset="utf-8">
     <!-- build:css css/main.css -->
     < link  rel="stylesheet" href="css/common.css">
     < link  rel="stylesheet" href="css/web.css">
     <!-- endbuild -->
 
     <!-- build:js js/main.js -->
     < script  src="js/zepto.js"></ script >
     < script  src="js/common.js"></ script >
     < script  src="js/service.js"></ script >
     <!-- endbuild -->
</ head >
< body >
< p ></ p >
Hello,Grunt!
</ body >
</ html >

执行grunt publish之后:

<!DOCTYPE html><html><head><title>Grunt 测试</title><meta charset=utf-8><link rel=stylesheet href=css/main.css><script src=js/main.js></script><body><p></p>Hello,Grunt<body><html>

最后

以上就是大气太阳最近收集整理的关于grunt常用模块的全部内容,更多相关grunt常用模块内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(65)

评论列表共有 0 条评论

立即
投稿
返回
顶部