mirror of
https://github.com/vuejs/vue-cli.git
synced 2026-04-21 20:08:41 -05:00
140 lines
8.5 KiB
Markdown
140 lines
8.5 KiB
Markdown
# Сервис 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/zkat/npx) (должен поставляться в комплекте с последней версией npm), то вы также можете запустить бинарник напрямую:
|
|
|
|
``` bash
|
|
npx vue-cli-service serve
|
|
```
|
|
|
|
::: tip Совет
|
|
Запускать команды с дополнительными возможностями можно из GUI через `vue ui`.
|
|
:::
|
|
|
|
Пример работы Webpack Analyzer запущенного из графического интерфейса:
|
|
|
|

|
|
|
|
## 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)
|
|
```
|
|
|
|
Команда `vue-cli-service serve` запускает сервер для разработки (основанный на [webpack-dev-server](https://github.com/webpack/webpack-dev-server)), предоставляющий из коробки функцию горячей замены модулей.
|
|
|
|
Кроме флагов командной строки, также можно настраивать сервер для разработки с помощью поля [devServer](../config/#devserver) в файле `vue.config.js`.
|
|
|
|
## vue-cli-service build
|
|
|
|
```
|
|
Использование: vue-cli-service build [options] [entry|pattern]
|
|
|
|
Опции:
|
|
|
|
--mode определить режим сборки (по умолчанию: production)
|
|
--dest определить каталог сборки (по умолчанию: dist)
|
|
--modern собирать приложение для современных браузеров с авто-фоллбэком для старых
|
|
--target app | lib | wc | wc-async (по умолчанию: app)
|
|
--name имя библиотеки или режим веб-компонента (по умолчанию: "name" в package.json или имя файла точки входа)
|
|
--no-clean не удалять каталог dist перед сборкой проекта
|
|
--report сгенерировать report.html для анализа содержимого сборки
|
|
--report-json сгенерировать report.json для анализа содержимого сборки
|
|
--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]
|
|
```
|
|
|
|
## Кэширование и параллелизация
|
|
|
|
- `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"
|
|
}
|
|
}
|
|
```
|
|
|
|
::: warning Предупреждение
|
|
`yorkie` — это форк [`husky`](https://github.com/typicode/husky) без обратной совместимости с ним.
|
|
:::
|
|
|
|
## Конфигурация без извлечения
|
|
|
|
Проекты созданные с помощью `vue create` уже готовы к работе без необходимости дополнительной настройки. Плагины предназначены для работы друг с другом, поэтому в большинстве случаев всё что вам нужно сделать — это выбрать необходимые возможности во время интерактивных запросов выбора.
|
|
|
|
Однако, мы также понимаем, что невозможно удовлетворить все возможные потребности, как и потребности проекта могут изменяться с течением времени. Поэтому проекты созданные Vue CLI позволяют настраивать практически все аспекты без необходимости извлечения конфигурации. Подробную информацию можно найти в разделе [Конфигурация](../config/).
|