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

0

138
Views
Reaccionar: en la carga inicial, mi matriz de estado solo guarda el último elemento

Tengo un proyecto React JS y el siguiente problema:

En el estado, tengo una matriz de decoradores y una matriz de polyPaths, es decir:

 this.state = { decorators = [], polyPaths = [], }

En mi método de renderizado, tengo el siguiente fragmento de código:

 {this.state.polyPath.map((polyline, index) => { return ( <PolylineDecorator patterns={arrow_blue} positions={polyline} color={"blue"} opacity={0.5} key={index} addDecorator={this.addDecorator} currDecorators={this.state.decorators} checkIfSamePath={this.checkIfSamePath} /> ); })}

Esto mapeará las polilíneas y generará un decorador de polilíneas.

En el componente PolylineDecorator , llamo al siguiente método:

 addDecorator = (dec) => { // Add decorator to state this.setState({ decorators: [...this.state.decorators, dec] }) }

Ahora mi problema es que, por alguna razón, si ya hay 2 elementos existentes en los polyPaths, solo el segundo decorador se guardará en el estado, es decir, los decoradores solo tendrán 1 elemento.

No estoy seguro de por qué sucede esto (¿tal vez porque está configurando el estado nuevamente demasiado rápido?), ¿Y qué podría hacer al respecto?

Sé que la función addDecorator se llama dos veces, con cada decorador respectivo, ¿solo guarda el último?

Gracias

almost 3 years ago · Juan Pablo Isaza
1 answers
Answer question

0

addDecorator = (dec) => { // Add decorator to state this.setState({ decorators: [...this.state.decorators, ...dec] }) }

use el operador de propagación en ambas matrices; de lo contrario, simplemente coloque la nueva matriz directamente dentro de la matriz anterior

o si quieres poner otra matriz nueva, hazlo

 addDecorator = (dec) => { // Add decorator to state this.setState({ decorators: dec }) }
almost 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