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

0

332
Views
Cómo configurar una tarjeta vuetify de diferentes colores con foreach VUEJS

Declaración del problema: estoy creando tarjetas con vuetify que se repetirán en foreach, pero quiero que cada tarjeta tenga un color diferente que obtengo de mi función generateColor() , esto es lo que quiero decir :

ingrese la descripción de la imagen aquí

ProyectoCard.vue :

 <template> <v-card :color="colorCard"> <v-row>{{ projectName }}</v-row> <v-row>{{ projectDecs }}</v-row> <v-row>{{ deadline }}</v-row> </v-card> </template> <script> export default { props: { projectName: String, projectDecs: String, deadline: String, colorCard: String, }, }; </script>

Proyecto.vue :

 <template> <v-container> <v-row> <v-col v-for="(project, index) in projects" :key="index"> <project-card :projectName="project.name" :projectDesc="project.desc" :deadline="project.date" :colorCard="this.color" ></project-card> </v-col> </v-row> </v-container> </template> <script> import ProjectCard from "@/components/ProjectCard.vue"; export default { components: { ProjectCard, }, data() { return { color: "", projects: [ { name: "Learning laravel", desc: "Finish video asap", date: "28", }, { name: "Learning laravel", desc: "Finish video asap", date: "28", }, ], }; }, mounted(){ this.generateColor() }, methods: { generateColor() { const colors = ["#c07bc3", "#a6dcaf", "#ddddce"]; this.color = colors[Math.floor(Math.random() * colors.length)]; }, } }; </script>

Sé que no podemos definir el color como accesorio :color="ColorCard" , y me estoy quedando sin ideas, ¿alguien puede ayudarme?

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

0

Puede intentar llamar al método para obtener un color aleatorio:

 Vue.component('projectCard', { template: ` <v-card :color="colorCard"> <v-row>{{ projectName }}</v-row> <v-row>{{ projectDecs }}</v-row> <v-row>{{ deadline }}</v-row> </v-card> `, props: { projectName: String, projectDecs: String, deadline: String, colorCard: String, }, }) new Vue({ el: '#app', vuetify: new Vuetify(), data() { return { colors: ["#c07bc3", "#a6dcaf", "#ddddce"], projects: [ {name: "Learning laravel", desc: "Finish video asap", date: "28",}, {name: "Learning laravel", desc: "Finish video asap", date: "28",}, ] } }, methods: { setColor() { return this.colors[Math.floor(Math.random() * this.colors.length)] }, }, })
 <link href="https://fonts.googleapis.com/css?family=Roboto:100,300,400,500,700,900" rel="stylesheet"> <link href="https://cdn.jsdelivr.net/npm/@mdi/font@6.x/css/materialdesignicons.min.css" rel="stylesheet"> <link href="https://cdn.jsdelivr.net/npm/vuetify@2.x/dist/vuetify.min.css" rel="stylesheet"> <div id="app"> <v-app> <v-main> <v-container> <v-row> <v-col v-for="(project, index) in projects" :key="index"> <project-card :project-name="project.name" :project-desc="project.desc" :deadline="project.date" :color-card="setColor()" ></project-card> </v-col> </v-row> </v-container> </v-main> </v-app> </div> <script src="https://cdn.jsdelivr.net/npm/vue@2.x/dist/vue.js"></script> <script src="https://cdn.jsdelivr.net/npm/vuetify@2.x/dist/vuetify.js"></script>

about 3 years ago · Juan Pablo Isaza Report

0

Lo que está tratando de hacer aquí es que está asignando un solo color para cada tarjeta, pero debe ser dinámico. Entonces, lo que puede intentar es asignar una propiedad de color en cada objeto de la matriz de projects y luego enlazar de la misma manera :color="colorCard" .

Creé esta demostración simple para su comprensión :

 new Vue({ el: '#app', vuetify: new Vuetify(), data: { cardsDetails: [{ title: 'Card A' }, { title: 'Card B' }, { title: 'Card C' }] }, created() { this.generateColor(); }, methods: { generateColor() { const colors = ["#c07bc3", "#a6dcaf", "#ddddce"]; this.cardsDetails.forEach(obj => { const color = colors[Math.floor(Math.random() * colors.length)]; obj.colorCard = color; }); } } })
 .mx-auto { margin: 5px }
 <script src="https://unpkg.com/vue@2.x/dist/vue.js"></script> <script src="https://unpkg.com/vuetify@2.6.7/dist/vuetify.min.js"></script> <link rel="stylesheet" href="https://unpkg.com/vuetify@2.6.7/dist/vuetify.min.css"/> <div id="app"> <v-app id="inspire"> <v-card v-for="(card, index) in cardsDetails" :key="index" class="mx-auto" max-width="344" :color="card.colorCard" > <v-card-text> <div>{{ card.title }}</div> </v-card-text> </v-card> </v-app> </div>

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