Автоматизация — передача рутинных задач разработки, которые могут быть выполнены вручную, в руки компьютера. Автоматизация переводит файлы, написанные и понятные разработчику, в сжатые коды, понятные браузеру, и формирует финишный пакет приложения.
Что дает автоматизация. Автоматизация экономит время разработчика, помогает найти и исправить ошибки. При этом создаются коды, которые экономят время браузера и ускоряют загрузку сайта.
Какие задачи могут быть автоматизированы. Например, минификация файлов (html, css, js), сжатие изображений, получение изображения определенных форматов (webp), сборка файла sprite.svg
, сборка пакета приложения.
С помощью каких инструментов осуществляется автоматизация. Сообществом программистов созданы целые библиотеки программ для автоматизации. Также есть системы для лёгкого доступа к этим библиотекам и использования их в разработке новых программ и приложений. Одной из таких систем является система Node.js.
Что такое Node.js
Node.js — интерпретатор языка JavaScript, который часто используют для автоматизации сборки проектов. Кроме Node.js нам понадобятся менеджер пакетов npm и менеджер задач Gulp.
Менеджер пакетов Npm (node package manager) устанавливается автоматически при установке на компьютер Node.js. Npm работает в консоли и выполняет команды, которые мы вводим в соответствии с синтаксисом, предлагаемым Node.js
Что делает npm для автоматизации
- Устанавливает пакеты программ из сторонних библиотек на наш компьютер прямо внутрь проекта.
- С помощью команд в консоли передает для выполнения на нашем компьютере задачи, написанные нами для менеджера задач Gulp.
- По нашему желанию переносит/публикует пакеты с нашего компьютера в библиотеку
Но как npm узнаёт, какие программы мы хотим использовать в нашей работе и как их скачать на наш компьютер? Есть два пути — скачать программы по одной или установить все сразу.
Первый путь. Мы скачиваем нужные программы по одной.
Мы через консоль сами задаем ему команду, какую программу/библиотеку/пакет мы хотим скачать. Например, после ввода команды npm скачает пакет gulp-less.
npm install –d gulp-less
Второй путь. Мы скачиваем все требующиеся для работы программы за раз. В этом случае Npm берет эти данные из файла package.json
.
Где взять package.json
Два варианта — взять готовый или написать самостоятельно.
Например, в корневой папке проектов в Академии уже лежит готовая версия такого файла. Позже вы научитесь составлять и модифицировать его самостоятельно под ваши задачи.
Что входит в файл package.json
В файл package.json
помещают информацию о приложении, которое мы разрабатываем.
Название, версия и другие базовые данные. Это на случай, если мы захотим опубликовать приложение, которое мы создаём. (Любая директория, в которой есть этот файл, интерпретируется как Node.js-пакет, даже если вы не собираетесь публиковать его).
Вот самый простой пример с базовой информацией:
{
"name": "my_package",
"description": "",
"version": "1.0.0",
"scripts": {
"test": "echo "Error: no test specified" && exit 1"
},
"repository": {
"type": "git",
"url": "https://github.com/monatheoctocat/my_package.git"
},
"keywords": [],
"author": "",
"license": "ISC",
"bugs": {
"url": "https://github.com/monatheoctocat/my_package/issues"
},
"homepage": "https://github.com/monatheoctocat/my_package"
}
Зависимости. Это программы из внешних библиотек, которые мы будем использовать или уже использовали в нашем приложении. Теперь, когда мы используем эти программы внутри своих программ, наши программы становятся зависимыми от них.
Зависимости для разработчиков (devDependencies). Это программы сторонних разработчиков, которые мы используем при разработке в качестве инструментов, в том числе для оптимизации или автоматизации.
npm scripts. Короткие команды для npm, которые мы сможем задавать через консоль.
Список требований к браузерам, на которые рассчитано наше приложение.
Как установить программы из в package.json
Если положить в пустую папку файл package.json
и в терминале набрать
npm install
или короткую версию команды
npm i
npm скачает все программы, которые указаны в package.json
. После выполнения команды внутри папки проекта появится папка node_modules
, в которую и будут помещены все программы, перечисленные в package.json
.
Мы тонем в зависимостях и нам это нравится
Что делать дальше, когда всё подключено
Теперь npm
отходит на второй план и в дело вступает менеджер задач Gulp. Это небольшая программа на JavaScript, которая позволяет нам подключать для решения задач нашей разработки сторонние программы из внешних библиотек.
Свои задачи (или таски — tasks), мы должны прописать в файле gulpfile.js
. В первоначальном виде этот файл также размещается корне вашего проекта. Как изменить gulpfile.js
под ваш проект или даже написать заново вы узнаете из лайвов на курсе «Адаптивная вёрстка и автоматизация».