Grunt - Настройка задач
Вы можете определить данные конфигурации для конкретного проекта для Grunt в файле Gruntfile.js .
Конфигурация Grunt
Данные конфигурации задачи могут быть инициализированы в файле Gruntfile с помощью метода grunt.initConfig () . Внутри функции grunt.initConfig () возьмите информацию о конфигурации из файла package.json. Конфигурация будет содержать задачу с именемproperties и любые произвольные данные.
grunt.initConfig({
jshint: {
// configuration for jshint task
},
cssmin: {
// configuration for cssmin task
},
// Arbitrary non-task-specific properties
my_files: ['dir1/*.js', 'dir2/*.js'],
});
Конфигурация задачи и цели
Когда вы запускаете задачу, Grunt ищет конфигурацию в свойстве с именем задачи. Мы определим задачи с несколькими конфигурациями и целевыми параметрами, как показано ниже -
grunt.initConfig({
jshint: {
myfile1: {
// configuration for "myfile1" target options
},
myfile2: {
// configuration for "myfile2" target options
},
},
cssmin: {
myfile3: {
// configuration for "myfile3" target options
},
},
});
Здесь jshint задача имеет myfile1 и myfile2 цели и cssmin задача имеет myfile3 цель. Когда вы запускаете grunt jshint , он будет перебирать как задачу, так и цель, чтобы обработать указанную конфигурацию цели.
Параметры
Определите свойство options в конфигурации задачи, которое переопределяет значения задачи по умолчанию. Каждая цель включает свойство options, которое переопределяет параметры уровня задачи. Он будет иметь следующий формат -
grunt.initConfig({
jshint: {
options: {
// task-level options that overrides task defaults
},
myfile: {
options: {
// "myfile" target options overrides task defaults
},
},
myfile1: {
// there is no option, target will use task-level options
},
},
});
Файлы
Grunt предлагает несколько идей по определению файлов, с которыми должна работать задача, и использует различные способы определения сопоставлений файлов src-dest . Ниже приведены некоторые из дополнительных свойств, которые поддерживаются сопоставлениями src и dest.
filter- Это функция, которая указывает совпадающий путь к файлу src и возвращает истинные или ложные значения.
nonull - Он определяет несоответствующие шаблоны, если для него установлено значение true.
dot - Соответствует именам файлов, начинающимся с точки или иначе.
matchBase - Соответствует шаблонам, содержащим косые черты, с базовым именем пути.
expand - Он обрабатывает отображение файла src-dest.
Компактный формат
Он определяет сопоставление файла src-dest для каждой цели, которое может использоваться для задач только для чтения и требует только свойства src и не свойства dest .
grunt.initConfig({
jshint: {
myfile1: {
src: ['src/file1.js','src/file2.js']
},
},
cssmin: {
myfile2: {
src: ['src/file3.js','src/file4.js'],
dest: 'dest/destfile.js',
},
},
});
Формат объекта файлов
Он определяет СРК-Dest отображение файла на каждую цель , в которой имя свойства Dest файла и его значение ЦСИ файл.
grunt.initConfig({
jshint: {
myfile1: {
files: {
'dest/destfile.js':['src/file1.js','src/file2.js'],
'dest/destfile1.js':['src/file3.js','src/file4.js'],
},
},
myfile2: {
files: {
'dest/destfile2.js':['src/file22.js','src/file23.js'],
'dest/destfile21.js':['src/file24.js','src/file25.js'],
},
},
},
});
Формат массива файлов
Он определяет сопоставление файла src-dest для каждой цели, используя дополнительные свойства для каждого сопоставления.
grunt.initConfig({
jshint: {
myfile1: {
files: [
{src:['src/file1.js','src/file2.js'],dest:'dest/file3.js'},
{src:['src/file4.js','src/file4.js'],dest:'dest/file5.js'},
],
},
myfile2: {
files: [
{src:['src/file6.js','src/file7.js'],dest:'dest/file8/', nonull:true},
{src:['src/file9.js','src/file10.js'],dest:'dest/file11/', filter:'isFalse'},
],
},
},
});
Старые форматы
Адр-в-целевой формат файл был до существования многозадачности , где файл назначения путем является именем цели. Следующий формат устарел и не должен использоваться в коде.
grunt.initConfig({
jshint: {
'dest/destfile2.js':['src/file3.js','src/file4.js'],
'dest/destfile5.js':['src/file6.js','src/file7.js'],
},
});
Пользовательская функция фильтра
Вы можете помочь целевым файлам с большим уровнем детализации, используя свойство filter . Следующий формат очищает файлы, только если он соответствует реальному файлу.
grunt.initConfig({
clean: {
myfile:{
src: ['temp/**/*'],
filter: 'isFile',
},
},
});
Шаблоны глобусов
Подстановка означает расширение имени файла. Grunt поддерживает подстановку с помощью встроенных библиотек node-glob и minimatch . Шаблон подстановки включает следующие моменты -
- * соответствует любому количеству символов, но не / .
- ? соответствует одиночному символу, но не / .
- ** соответствует количеству символов, включая / .
- {} задает список выражений "или", разделенных запятыми.
- ! отменит совпадение с образцом в начале.
Например -
{src: 'myfile/file1.js', dest: ...} // it specifies the single file
{src: 'myfile/*.js', dest: ...} //it matches all the files ending wth .js
{src: 'myfile/{file1,file2}*.js', dest: ...} //defines the single node glob pattern
{src: ['myfile/*.js', '!myfile/file1.js'], dest: ...} // all files will display in alpha
// order except for file1.js
Динамическое построение объекта Files
Когда вы работаете с отдельными файлами, вы можете использовать дополнительные свойства для динамического построения списка файлов. Когда вы устанавливаетеexpand значение true, он активирует некоторые из следующих свойств:
cwd сопоставляет все src с этим путем.
src сопоставляет образцы для сопоставления относительно cwd .
Свойство dest указывает префикс пути назначения.
внутр заменит существующее расширение с значением , генерируемым в Dest пути.
extDot указывает, где находится период, указывающий на расширение. Используется либо первый период, либо последний период; по умолчанию установлен первый период
Flatten удаляет все части пути от Dest путей.
rename указывает строку, содержащую новое место назначения и имя файла.
Переименовать свойство
Это уникальная функция JavaScript, которая возвращает строку, и вы не можете использовать строковое значение для переименования. В следующем примере задача копирования создаст резервную копию README.md.
grunt.initConfig({
copy: {
backup: {
files: [{
expand: true,
src: ['docs/README.md'], // creating a backup of README.md
rename: function () { // specifies the rename function
return 'docs/BACKUP.txt'; // returns a string with the complete destination
}
}]
}
}
});
Шаблоны
Вы можете указать шаблоны, используя разделители < %% > . Они будут автоматически расширяться при чтении из конфига. Он включает в себя два типа свойств -
<%= prop.subprop %>Свойство используется для расширения значения prop.subprop в конфигурации, которое может ссылаться на строковые значения, массивы и другие объекты.
<% %> свойство выполняет встроенный код JavaScript, который используется для потока управления или цикла.
Например -
grunt.initConfig({
concat: {
myfile: {
options: {
banner: '/* <%= val %> */\n',
},
src: ['<%= myval %>', 'file3/*.js'],
dest: 'build/<%= file3 %>.js',
},
},
// properties used in task configuration templates
file1: 'c',
file2: 'b<%= file1 %>d',
file3: 'a<%= file2 %>e',
myval: ['file1/*.js', 'file2/*.js'],
});
Импорт внешних данных
Вы можете импортировать внешние данные из файла package.json . Плагин grunt- contribuglify можно использовать для минимизации исходного файла, и он создает комментарий баннера с использованием метаданных. Вы можете использовать grunt.file.readJSON и grunt.file.readYAML для импорта данных JSON и YAML.
Например -
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
uglify: {
options: {
banner: '/*! <%= pkg.name %> <%= grunt.template.today("yyyy-mm-dd") %> */\n'
},
dist: {
src: 'src/<%= pkg.name %>.js',
dest: 'dist/<%= pkg.name %>.min.js'
}
}
});