Vue.Js Flashcards
How to install Vue and create a Vue project from template?
In terminal write: npm install -g @vue/cli
Then to create a project: Vue create project name
Which function inserts your component into your html?
import { createApp } from Vue
createApp(component name”).mount({html selector})
How to create a Vue.js component?
- Create it in your script as a JS object (rarely used and unintuitive)
- Single file component method - create a separate file with sections : template (html), script (JS), style (CSS), and export it from the file into your main script
Что такое интерполяция во Vue? Как её использовать?
Интерполяция Vue это использование переменных из data() компонента внутри верстки. Используется так: У нас есть компонент, с script фрагментом, который выглядит так: script export default { data(){ return { variable : 0, } } } script
Используем:
template
p what is the value? It’s {{ variable }}! p
template
Каким образом можно добавить обработку нажатия кнопки внутри one file компонента Vue?
Создать функцию обработки нажатия в секции в методе компонента под названием methods script:
export default{ data(){ return { "variable" : 0; } } methods(){ clickprocess(){ this.variable++; } } }
Добавить обработку в template:
button @v-on:click=”clickprocess” button
v-on: click лучше заменить на короткую версию: @click
Как можно легко дебажить vue приложение?
Скачать расширение Vue devtools (beta для третей версии Vue)
Как реализовываться двухстороннее связывание? (Как связать например форму и переменную в компоненте?
С помощью v-bind:attribute и обработчика ввода
Template Form input type=text v-bind:value="variable" @input="processInput" Form Template
export default{ data(){ return { "variable" : 0; } } methods(){ process Input(input){ this.variable = input.value } } }
Process Input метод оптимизируется таким образом:
input type=text v-bind:value=”variable” @input=”variable = $event.target.value”
$event это зарезервированное во Vue значение
How to prevent a Vue form from submitting?
Form @submit.prevent
Как вставить один компонент Vue в другой?
Как передать ему данные?
Нужно импортировать в его секцию script, и зарегистрировать его в components поле экспорта:
script
import Component from “@/components/Component
export default { components:{ Component, Component2 } }
Как передать данные в импортированный компонент?
Нужно использовать директиву v-bind, а внутри самого компонента использовать поле props в экспорте
Компонент родитель:
template
child :data=”parentVar”
template
Импортированный компонент script export default { props: { data: { type: Array, required: true } } }
Можно ли изменять данные, переданные компоненту через props?
Нет
Как называется директива, заменяющая все типы двухстороннего связывания, включающая в себя событие (onclick например) и привязку v-bind?R
V-model = “variable”
Как передать данные из импортированного компонента в компонента родителя?
Сгенерировать событие в компоненте ребенке с помощью emit, и подписаться на это событие в родителе
Пример:
Родитель -
template
child @create=”ProcessCreation” // список аргументов функции - данные, которые отсылает emit в ht,tyrt
template
Ребенок: methods:{ onclick(){ this.$emit('create', this.data); } }
Как поместить что-либо вовнутрь импортированного компонента Vue?
В вёрстке дочернего компонента создать слот для элементов
template div slot slot div template
Как экспортировать сразу все компоненты и не включать их по одному?
Создать отдельный js файл, импортировать их туда, экспортировать обьект с этими всеми компонентами
В основном js файле массивом все зарегистрировать через функцию .component