Хорошо, так что школы на сессии (извините, если я иногда объясняю слишком простые вещи, просто пытаюсь быть тщательными).
Вот базовая структура для проекта Vue, использующего vue init webpack-simple my-project
:
- src /
- .babelrc
- .gitignore
- index.html
- package.json
- README.md
- webpack.config.js
Папка src
содержит все исходные файлы вашего проекта.
Папка src/assets
содержит все ваши ресурсы, в первую очередь изображения.
App.vue
- это первое «представление» вашего приложения.
main.js
- это основной скрипт вашего проекта, в котором вы конфигурируете и запускаете Vue.Именно здесь вы загружаете все, что должно существовать в глобальной области видимости вашего приложения.
.babelrc
определяет, как инструмент babel должен синтаксически проверять ваш код.
.gitignore
говорит Git игнорироватьопределенные файлы от коммитов.
index.html
- это страница, которая отправляется в браузер клиентов.Здесь мы загружаем файл main.js и помещаем все необходимые метаданные (если вы не используете, например, vue-meta, чтобы обрабатывать их там).Обратите внимание, что <div id="app">
html tag - это место, куда монтируются все ваши файлы Vue.
package.json
- это наш файл конфигурации npm.Когда вы запускаете, например, npm install --save component-from-npm-name, он сохраняется здесь, так что вы можете просто запустить npm install позже, чтобы получить все зависимости вашего проекта.
README.md
- это файл документации вязыковой формат Markdown.Он отображается как главная страница вашего проекта, например, на Github или Gitlab.
webpack.config.js
- это файл Node.js, который отвечает за запуск Webpack в вашем проекте.Vue можно использовать без Webpack, но я не рекомендую его.Вы можете запустить node webpack.config.js
напрямую, чтобы построить свой проект.Этот файл является вашим скриптом сборки, вы настроили его для обработки процесса сборки вашего проекта.
Итак, вооружившись этой информацией, давайте перейдем к вашему вопросу.
Как загрузить компонентв Vue.js?
- Запустите
npm install --save vue-accordion
(обратите внимание, что пока исходный код размещен на Github, пакет загружается отсюда: https://www.npmjs.com/package/vue-accordion) - В вашем
index.js
файл, который отвечает за загрузку вещей в ваше приложение Vue в глобальном контексте, вы делаете, как сообщает страница Github, сначала import {vueAccordion} from 'vue-accordion'
, затем запускаете Vue.component('vue-accordion', vueAccordion)
, чтобы зарегистрировать его в глобальном контексте.
Это все, что нужно. index.js
- это ваша точка входа для вашего приложения Vue, а webpack.config.js
- ваш скрипт сборки.
Однако существует альтернативное решение для загрузки компонентов.В предыдущем варианте мы загрузили его в index.js
, чтобы загрузить его в глобальном контексте, то есть вы можете использовать компонент сейчас в любом месте вашего приложения, но что делать, если вы хотите загружать его только по мере необходимости (вам нужнохочу сделать это для перформансаПричины)?
Что ж, в вашем файле App.vue
есть тег <script>
, в котором вы можете настроить вещи только в этом компоненте Vue (все файлы .vue являются компонентами Vue, даже если вы называете их маршрутами, страниц, просмотров или что-либо, чтобы указать их цель).Чтобы загрузить компонент не в глобальном контексте, а в контексте компонента, вы должны сделать следующее в App.vue
:
<script>
import Accordion from 'vue-accordion';
export default {
components: {
'vue-accordion': Accordion
}
</script>
Tips ...
- Это всего лишь одна настройка для проекта Vue.Проект Vue может быть таким простым, как простая загрузка Vue в виде скрипта в ваш статический файл index.html, тогда вы можете иметь гораздо более раздражающую установку с обычными файлами javascript, но это глупо и неэффективно.Итак, у правильного проекта есть файл Node.js для запуска Webpack.В зависимости от того, как вы конфигурируете Webpack, ваш проект может действовать совершенно иначе, чем любой другой проект Webpack.
- Узнайте больше о том, как работает Webpack, чтобы вы могли иметь структуру проекта, которая имеет смысл для вас.
- Взгляните на Nuxt, это по сути набор других проектов (в первую очередь Vue и Webpack), которые упрощают создание мощного проекта Vue.Вы можете сидеть и настроить свой собственный проект Vue и все инструменты самостоятельно и получить тот же результат, но Nuxt упростит вам задачу.