sidebarDepth |
---|
1 |
Si está utilizando una compilación de CDN, luego las funciones de la API global son disponibles mediante el objeto global Vue
. p. ej.:
const { createApp, h, nextTick } = Vue
Si está utilizando módulos ES, luego pueden ser importados directamente:
import { createApp, h, nextTick } from 'vue'
Las funciones globales que se encargan de la reactividad, como reactive
y ref
, son documentadas por separado. Vea API de Reactividad para estas funciones.
Retorna una instancia de aplicación que proporciona un contexto de aplicación. El árbol completo de componentes montado por la instancia de aplicación comparte el mismo contexto.
const app = createApp({})
Puede encadenar otros métodos después de createApp
, los cuales se pueden encontrar en API de Aplicación
La función recibe un objeto de opciones de componente raíz como el primer parámetro:
const app = createApp({
data() {
return {
...
}
},
methods: {...},
computed: {...}
...
})
Con el segundo parámetro, podemos pasar props raíz a la aplicación:
const app = createApp(
{
props: ['username']
},
{ username: 'Evan' }
)
<div id="app">
<!-- se mostrará 'Evan' -->
{{ username }}
</div>
Las props raíz son props crudas, muy similar a esos pasados a h
para crear un VNode. Además de props de componente, pueden también incluir atributos y escuchadores de evento que se van a aplicar al componente raíz.
interface Data {
[key: string]: unknown
}
export type CreateAppFunction<HostElement> = (
rootComponent: PublicAPIComponent,
rootProps?: Data | null
) => App<HostElement>
Retorna un "nodo virtual", usualmente abreviado a VNode: un objeto plano que contiene información describiendo a Vue qué tipo de nodo se debe renderizar en la página, incluyendo descripciones de cualquier nodo hijo. Es destinado para funciones de render escritos manualmente:
render() {
return h('h1', {}, 'Algún título')
}
Acepta tres argumentos: type
, props
y children
-
Tipo:
String | Object | Function
-
Detalles:
Un nombre de etiqueta HTML, un componente, un componente asíncrono, o un componente funcional. Se renderizaría un comentario al utilizar una función que retorne null. Este parámetro es requerido
-
Tipo:
Object
-
Detalles:
Un objeto correspondiente a los atributos, props y eventos que podríamos utilizar en una plantilla. Opcional
-
Tipo:
String | Array | Object
-
Detalles:
VNodes hijos, construidos utilizando
h()
, o cadenas de caracteres para obtener "VNodes de texto" o un objeto con slots. Opcionalh('div', {}, [ 'Se va algún texto primero.', h('h1', 'Un titular'), h(MyComponent, { someProp: 'foobar' }) ])
Cuando se trate de la implementación, defineComponent
no nace nada sino retorna el objeto pasado a el. Sin embargo, en términos de tipar, el valor retornado tiene un constructor de tipo sintético para función manual de render, TSX y soporte de herramienta de IDE.
Un objeto con opciones de componente
import { defineComponent } from 'vue'
const MyComponent = defineComponent({
data() {
return { count: 1 }
},
methods: {
increment() {
this.count++
}
}
})
O una función setup
, el nombre de la función será utilizado como nombre de componente
import { defineComponent, ref } from 'vue'
const HelloWorld = defineComponent(function HelloWorld() {
const count = ref(0)
return { count }
})
Crea un componente asíncrono que se va a cargar solo cuando sea necesario.
Para uso básico, defineAsyncComponent
puede aceptar una función de fábrica que retorne un Promise
. El callback resolve
del Promise será llamado cuando haya recuperado su definición de componente desde el servidor. Puede también llamar reject(reason)
para indicar que la carga haya fallado.
import { defineAsyncComponent } from 'vue'
const AsyncComp = defineAsyncComponent(() =>
import('./components/AsyncComponent.vue')
)
app.component('async-component', AsyncComp)
Cuando utiliza registración local, puede también proporcionar directamente una función que retorne u Promise
:
import { createApp, defineAsyncComponent } from 'vue'
createApp({
// ...
components: {
AsyncComponent: defineAsyncComponent(() =>
import('./components/AsyncComponent.vue')
)
}
})
Para uso avanzado, defineAsyncComponent
puede aceptar un objeto del formato siguiente:
import { defineAsyncComponent } from 'vue'
const AsyncComp = defineAsyncComponent({
// La función de fábrica
loader: () => import('./Foo.vue'),
// Un componente para utilizar mientras se carga el componente asíncrono
loadingComponent: LoadingComponent,
// Un componente para utilizar si la carga falla
errorComponent: ErrorComponent,
// La demora antes de mostrar el componente de cargamente. Por defecto: 200ms.
delay: 200,
// El componente de error será mostrado si un tiempo fuera sea
// proporcionado y excedido. Por defector: Infinity.
timeout: 3000,
// Definir si el componente soporta suspenderse (suspensible). Por defecto: true.
suspensible: false,
/**
*
* @param {*} error Objeto de mensaje de error
* @param {*} retry Una función que indica si el componente asíncrono deba reintentar cuando el _promise_ de cargador rechace
* @param {*} fail Terminar de fallo
* @param {*} attempts El tiempo máximo permitido para reintentar
*/
onError(error, retry, fail, attempts) {
if (error.message.match(/fetch/) && attempts <= 3) {
// reintentar cuando se produce un fallo de recuperar, al máximo 3 intentos
retry()
} else {
// Note que retry/fail se comportan como resolve/reject de un promise:
// uno de ellos debe ser llamado para continuar la manipulación de errores
fail()
}
},
})
Vea también: Componentes Dinámicos & Asíncronos
Este método acepta el mismo argumento como defineComponent
, pero en cambio retorna un Elemento Personalizado nativo que pueda ser utilizado dentro de cualquier framework, o sin frameworks por completo.
Ejemplo de uso:
<my-vue-element></my-vue-element>
import { defineCustomElement } from 'vue'
const MyVueElement = defineCustomElement({
// opciones normales de componente Vue aquí
props: {},
emits: {},
template: `...`,
// sólo para defineCustomElement: el CSS para ser inyectado en raíz de _shadow_
styles: [`/* css alineado */`]
})
// Registrar el elemento personalizado.
// Después de la registración, todas etiquetas `<my-vue-element>` en la página serán actualizadas.
customElements.define('my-vue-element', MyVueElement)
// Puede también programáticamente instanciar el elemento:
// (solo puede hacerlo después de la registración)
document.body.appendChild(
new MyVueElement({
// props iniciales (opcional)
})
)
Para más detalles sobre construir componentes web con Vue, especialmente con componentes de un solo archivo, vea Vue y Componentes Web.
:::warning
resolveComponent
solo puede ser utilizado dentro de funciones render
o setup
.
:::
Permite resolver un componente por su nombre, si es disponible en la instancia actual de aplicación.
Retorna un componente o el argumento name
si no se encuentra uno.
const app = createApp({})
app.component('MyComponent', {
/* ... */
})
import { resolveComponent } from 'vue'
render() {
const MyComponent = resolveComponent('MyComponent')
}
Acepta un argumento: name
-
Tipo:
String
-
Detalles:
El nombre de un componente cargado.
:::warning
resolveDynamicComponent
solo puede ser utilizado dentro de funciones render
o setup
.
:::
Permite resolver un componente por el mismo mecanismo utilizado por <component :is="">
.
Retorna un componente resuelto o un VNode
recién creado con el nombre del componente como la etiqueta del nodo. Lanzará una advertencia si no se encuentra el componente.
import { resolveDynamicComponent } from 'vue'
render () {
const MyComponent = resolveDynamicComponent('MyComponent')
}
Acepta un argumento: component
-
Tipo:
String | Object (el objeto de opciones del componente)
-
Detalles:
Para más detalles, refiérase a la documentación sobre Componentes Dinámicos & Asíncronos.
:::warning
resolveDirective
solo puede ser utilizado dentro de funciones render
o setup
.
:::
Permite resolver una directiva por su nombre, si es disponible en la instancia actual de aplicación.
Retorna una directiva o undefined
cuando no se encuentra una.
const app = createApp({})
app.directive('highlight', {})
import { resolveDirective } from 'vue'
render () {
const highlightDirective = resolveDirective('highlight')
}
Acepta un argumento: name
-
Tipo:
String
-
Detalles:
El nombre de la directiva cargada.
:::warning
withDirectives
solo puede ser utilizado dentro de funciones render
o setup
.
:::
Permite aplicar directivas a un VNode. Retorna un VNode con las directivas aplicadas.
import { withDirectives, resolveDirective } from 'vue'
const foo = resolveDirective('foo')
const bar = resolveDirective('bar')
return withDirectives(h('div'), [
[foo, this.x],
[bar, this.y]
])
Acepta dos argumentos: vnode
y directives
.
-
Tipo:
vnode
-
Detalles:
Un nodo virtual, usualmente creado por
h()
.
-
Tipo:
Array
-
Detalles:
Una matriz de directivas.
Cada directiva es en sí mismo una matriz, lo cual permite un máximo de 4 índices definidos como se ve en el ejemplo siguiente.
[directive]
- La directiva por sí mismo. Requerida.
const MyDirective = resolveDirective('MyDirective') const nodeWithDirectives = withDirectives(h('div'), [[MyDirective]])
[directive, value]
- como se describe arriba, más un valor de tipoany
para ser asignado a la directiva
const MyDirective = resolveDirective('MyDirective') const nodeWithDirectives = withDirectives(h('div'), [[MyDirective, 100]])
[directive, value, arg]
- como se describe arriba, más un argumentoString
, p. ej.click
env-on:click
const MyDirective = resolveDirective('MyDirective') const nodeWithDirectives = withDirectives(h('div'), [ [MyDirective, 100, 'click'] ])
[directive, value, arg, modifiers]
- como se describe arriba, más unObject
con pareskey: value
para definir cualquieres modificadores.
const MyDirective = resolveDirective('MyDirective') const nodeWithDirectives = withDirectives(h('div'), [ [MyDirective, 100, 'click', { prevent: true }] ])
La función createRenderer
acepta dos argumentos genéricos:
HostNode
y HostElement
, correspondiente a tipos Node y Element en el entorno de acogida.
Por ejemplo, para runtime-dom, HostNode sería la interfaz Node
de DOM y HostElement sería la interfaz Element
de DOM.
Se puede pasar tipos específicos de la plataforma a renderizadores personalizados como esto:
import { createRenderer } from 'vue'
const { render, createApp } = createRenderer<Node, Element>({
patchProp,
...nodeOps
})
Acepta dos argumentos: HostNode
y HostElement
-
Tipo:
Node
-
Detalles:
El nodo en el entorno de acogida.
-
Tipo:
Element
-
Detalles:
El elemento en el entorno de acogida.
Diferir la ejecución del callback hasta después el proximo ciclo de actualización de DOM. Utilícelo inmediatamente después de que haya cambiado algún dato para esperar a la actualización de DOM.
import { createApp, nextTick } from 'vue'
const app = createApp({
setup() {
const message = ref('Hello!')
const changeMessage = async newMessage => {
message.value = newMessage
await nextTick()
console.log('Now DOM is updated')
}
}
})
Vea también: el método de instancia $nextTick
Toma múltiples objetos que contienen props de VNode y fundirlos en un solo objeto. Retorna un objeto recién creado, los objetos pasados como argumentos no se modifican.
Cualquier número de objetos pueden ser pasados, con las propiedades que previenen de argumentos posteriores toman precedencia. Los escuchadores de evento son manejados especialmente, así como class
y style
, siendo los valores de estas propiedades fundidos en vez de sobreescritos.
import { h, mergeProps } from 'vue'
export default {
inheritAttrs: false,
render() {
const props = mergeProps(
{
// La clase será fundida con cualquier clase proviene de $attrs
class: 'active'
},
this.$attrs
)
return h('div', props)
}
}
:::warning
useCssModule
solo puede ser utilizado dentro de funciones render
o setup
.
:::
Permite que los módulos CSS puedan ser accesados dentro de la función setup
de un componente de un solo archivo:
<script>
import { h, useCssModule } from 'vue'
export default {
setup() {
const style = useCssModule()
return () =>
h(
'div',
{
class: style.success
},
'Task complete!'
)
}
}
</script>
<style module>
.success {
color: #090;
}
</style>
Para más información sobre utilizar módulos CSS, vea Característica de Estilos de SFC: <style module>
.
Acepta un argumento: name
-
Tipo:
String
-
Detalles:
El nombre del módulo CSS, por defecto
'$style'
.
Proporciona el vesión de Vue instalado como una cadena de caracteres.
const version = Number(Vue.version.split('.')[0])
if (version === 3) {
// Vue 3
} else if (version === 2) {
// Vue 2
} else {
// versiones de Vue no soportados
}
Vea también: API de Aplicación - versión