• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

255
Views
Manera elegante de usar componentes dinámicos con accesorios en Vue

El siguiente caso: tengo una API que genera todo el contenido de mi página, así como su estructura, etc. generar contenido de páginas, que esa API entrega al front-end).

La estructura de la salida de la API se vería así:

 {content: [ {component: hero, content: {...} }, {component: form, content: {...} }, ... ]}

Entonces, para generar contenido relacionado, pensaría en usar componentes dinámicos como:

 <template v-for="item in content"> <component :is="item.component" /> </template>

Sin embargo, al hacerlo, enfrentaría el problema de que tengo que agregar datos de propiedades a mis componentes de alguna manera, lo cual (por lo que pude ver) no se describe en la documentación de Vue. Así que ahora me pregunto cómo pasar accesorios a componentes dinámicos, que tienen accesorios completamente diferentes (el héroe podría tener una imagen, el formulario podría tener marcadores de posición de entrada, etc.). ¿Alguna idea?

about 3 years ago · Juan Pablo Isaza
2 answers
Answer question

0

Hoy en día es necesario indicar con qué versión de Vue trabajas.

Con Vue 2 podrías hacerlo así:

 Vue.component('FirstComponent', { props: ['title', 'prop1_1'], template: ` <div> {{ title }}<br /> {{ prop1_1 }} </div> ` }) Vue.component('SecondComponent', { props: ['title', 'prop2_1', 'prop2_2'], template: ` <div> {{ title }}<br /> {{ prop2_1 }}<br /> {{ prop2_1 }} </div> ` }) new Vue({ el: "#app", data() { return { items: [ { component: 'FirstComponent', props: { title: 'First component title', prop1_1: 'this is prop 1_1' }, }, { component: 'SecondComponent', props: { title: 'Second component title', prop2_1: 'this is prop 2_1', prop2_2: 'this is prop 2_2', }, }, ] } }, template: ` <div> <component v-for="(item, idx) in items" :key="idx" :is="item.component" v-bind="item.props" ></component> </div> ` })
 <script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.5.17/vue.js"></script> <div id="app"></div>

about 3 years ago · Juan Pablo Isaza Report

0

Eche un vistazo a v-bind https://vuejs.org/v2/guide/components-props.html#Passing-the-Properties-of-an-Object (igual que Vue 3).

Suponiendo que su API incluye una propiedad de props para cada componente, entonces haría esto:

 <component v-for="item in content" :is="item.component" v-bind="item.props"></component>
about 3 years ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error