# Сервис CLI ## Использование Binary Внутри проекта Vue CLI, `@vue/cli-service` устанавливает бинарник `vue-cli-service`. К нему можно получить доступ через `vue-cli-service` в npm-скриптах, или через `./node_modules/.bin/vue-cli-service` из терминала. Это то, что вы увидите в `package.json` проекта с пресетом настроек по умолчанию: ```json { "scripts": { "serve": "vue-cli-service serve", "build": "vue-cli-service build" } } ``` Вы можете вызвать эти команды с помощью npm или Yarn: ```bash npm run serve # ИЛИ yarn serve ``` Если у вас установлен [npx](https://github.com/npm/npx) (должен поставляться в комплекте с последней версией npm), то вы также можете запустить бинарник напрямую: ```bash npx vue-cli-service serve ``` ::: tip Совет Запускать команды с дополнительными возможностями можно из GUI через `vue ui`. ::: Пример работы Webpack Analyzer запущенного из графического интерфейса: ![UI Webpack Analyzer](/ui-analyzer.png) ## vue-cli-service serve ``` Использование: vue-cli-service serve [options] [entry] Опции: --open открыть браузер при запуске сервера --copy скопировать url в буфер обмена при запуске сервера --mode определить режим сборки (по умолчанию: development) --host определить хост (по умолчанию: 0.0.0.0) --port определить порт (по умолчанию: 8080) --https использовать https (по умолчанию: false) --public указать URL-адрес публичной сети для клиента HMR --skip-plugins имена плагинов через запятую, которые следует пропустить при запуске ``` ::: tip --copy Копирование в буфер обмена может не работать на некоторых платформах. Если копирование выполнилось успешно, то рядом с URL-адресом локального сервера разработки будет отображено `(copied to clipboard)`. ::: Команда `vue-cli-service serve` запускает сервер для разработки (основанный на [webpack-dev-server](https://github.com/webpack/webpack-dev-server)), предоставляющий из коробки функцию горячей замены модулей. Кроме флагов командной строки, также можно настраивать сервер для разработки с помощью поля [devServer](../config/#devserver) в файле `vue.config.js`. В команде CLI `[entry]` означает *входной файл* (по умолчанию: `src/main.js` или `src/main.ts` в проектах с TypeScript), а не *дополнительный входной файл*. Если вы перезапишете запись в CLI, тогда записи из `config.pages` больше не будут учитываться, что может привести к ошибке. ## vue-cli-service build ``` Использование: vue-cli-service build [options] [entry|pattern] Опции: --mode определить режим сборки (по умолчанию: production) --dest определить каталог сборки (по умолчанию: dist) --modern собирать приложение для современных браузеров с авто-фоллбэком для старых --no-unsafe-inline собирать приложение без внедрения инлайн-скриптов --target app | lib | wc | wc-async (по умолчанию: app) --formats список выходных форматов для сборок библиотек (по умолчанию: commonjs,umd,umd-min) --inline-vue включить Vue в содержимое сборки библиотеки или веб-компонента --name имя библиотеки или режим веб-компонента (по умолчанию: "name" в package.json или имя файла точки входа) --filename имя выходного файла, только для 'lib' (по умолчанию: значение --name) --no-clean не удалять каталог dist перед сборкой проекта --report сгенерировать report.html для анализа содержимого сборки --report-json сгенерировать report.json для анализа содержимого сборки --skip-plugins имена плагинов через запятую, которые следует пропустить при запуске --watch отслеживать изменения ``` Команда `vue-cli-service build` создаёт готовую для production сборку в каталоге `dist/` с минификацией для JS / CSS / HTML и автоматическим разделением вендорного кода в отдельный фрагмент для лучшего кэширования. Манифест фрагмента вставляется инлайн в HTML. Есть несколько полезных флагов: - `--modern` собирает ваше приложение, используя [Современный режим](./browser-compatibility.md#современный-режим), поставляет нативный код ES2015 в современные браузеры, которые поддерживают его, а также автоматический fallback на сборку для старых браузеров. - `--target` позволяет вам создавать любые компоненты внутри вашего проекта в виде библиотек или веб-компонентов. Подробнее в разделе [Цели сборки](./build-targets.md). - `--report` и `--report-json` будут генерировать отчёты на основе полученной статистики сборки, которые помогут вам анализировать размеры модулей, используемых в сборке. ## vue-cli-service inspect ``` Использование: vue-cli-service inspect [options] [...paths] Опции: --mode определить режим сборки (по умолчанию: development) ``` Вы можете использовать `vue-cli-service inspect` для проверки конфигурации webpack внутри проекта Vue CLI. Подробнее в разделе [просмотр конфигурации Webpack проекта](./webpack.md#просмотр-конфигурации-webpack-проекта). ## Список всех доступных команд Некоторые плагины CLI добавляют собственные команды в `vue-cli-service`. Например, `@vue/cli-plugin-eslint` внедряет команду `vue-cli-service lint`. Вы можете посмотреть весь список команд запустив: ```bash npx vue-cli-service help ``` Вы также можете узнать о доступных параметрах каждой команды с помощью: ```bash npx vue-cli-service help [command] ``` ## Пропуск плагинов Иногда при выполнении команды может понадобиться не использовать определённый плагин CLI. К примеру, для создания сборки приложения без плагина PWA. Такого можно добиться передав имя плагина в опцию `--skip-plugins`. ```bash npx vue-cli-service build --skip-plugins pwa ``` ::: tip СОВЕТ Опция доступна для _любых_ команд `vue-cli-service`, включая пользовательские команды, добавленные другими плагинами. ::: Можно пропустить несколько подключаемых плагинов, передав их имена через запятую: ```bash npx vue-cli-service build --skip-plugins pwa,apollo ``` Имена плагинов разрешаются также, как и при установке, что подробнее описано [здесь](./plugins-and-presets.md#установка-пnагинов-в-существующий-проект) ```bash # все вызовы равнозначны npx vue-cli-service build --skip-plugins pwa npx vue-cli-service build --skip-plugins @vue/pwa npx vue-cli-service build --skip-plugins @vue/cli-plugin-pwa ``` ## Кэширование и параллелизация - `cache-loader` используется для компиляции Vue / Babel / TypeScript по умолчанию. Файлы кэшируются внутри `node_modules/.cache` — если при запуске будут возникать проблемы с компиляцией, сначала попробуйте удалить каталог кэша. - `thread-loader` будет использоваться для транспиляции Babel / TypeScript, когда в системе доступно более 1 процессорного ядра. ## Git хуки После установки `@vue/cli-service` также добавляется [yorkie](https://github.com/yyx990803/yorkie), который позволяет легко указывать Git хуки, используя поле `gitHooks` в файле `package.json`: ```json { "gitHooks": { "pre-commit": "lint-staged" }, "lint-staged": { "*.{js,vue}": [ "vue-cli-service lint", "git add" ] } } ``` ::: warning Предупреждение `yorkie` — это форк [`husky`](https://github.com/typicode/husky) без обратной совместимости с ним. ::: ## Конфигурация без извлечения Проекты, созданные с помощью `vue create` уже готовы к работе без необходимости дополнительной настройки. Плагины предназначены для работы друг с другом, поэтому в большинстве случаев всё что вам нужно сделать — это выбрать необходимые возможности во время интерактивных запросов выбора. Однако мы также понимаем, что невозможно удовлетворить все возможные потребности, как и потребности проекта могут изменяться с течением времени. Поэтому проекты, созданные Vue CLI, позволяют настраивать практически все аспекты без необходимости извлечения конфигурации. Подробную информацию можно найти в разделе [Конфигурация](../config/).