Pular para o conteúdo principal

React - Elevando o state (state lift)

Como visto anteriormente, o fluxo de informações no React é unidirecional, partindo sempre do componente pai para os filhos, logo um componente pai desconhece o que acontece com o estado presente nos seus componentes filhos.

Então como é que nós fazemos quando precisamos que com que um componente filho produza ou modifique um valor para que esse possa ser utilizado pelo componente pai? Bom a resposta para essa pergunta esta no titulo da postagem, resolvemos essa questão com a elevação do "state".

A elevação do "state" em tese é algo relativamente simples, basta mudar o estado do filho para o pai, logo o filho não mais trabalhará com seu estado, ele receberá o estado do pai por meio das "props" e quando for necessário alterar o estado o componente filho deve chamar um método do pai, que também estará presente em "props".

Exemplo

No exemplo abaixo criaremos um componente "filho" que oferece uma lista de opções de acordo com um tipo, ao escolher um item esse valor deve ser retornado para o componente pai:

import React, { Component } from 'react'

class Lista extends Component {
       
    handleClick(codigo) {
        this.props.onOptionChange(codigo);
    }

    render() {
        return(
            <ul>
                {this.props.lista === undefined 
<li /> 
this.props.lista.map((item=>
                    <li 
                        key={item.codigo} 
                        onClick={this.handleClick.bind(thisitem.codigo)}
                        value={item.nome}
                        >                        
                        {item.nome}
                    </li>
                )}
            </ul>        
            );            
    }
}

export default Lista

No componente "Lista" recebemos um "array" que é mostrado para seleção, sempre que um item é clicado o mesmo é incluído em uma outra lista no pai.

import React from 'react';
import logo from './logo.svg';
import './App.css';
import Lista from './Lista';

class App extends React.Component {

  listaValores = [
    {codigo: 1007nome:"Memoria ram"tipo:"PC"},
    {codigo: 1009nome:"Teclado sem fio"tipo:"PC"},
    {codigo: 1012nome:"Monitor"tipo:"PC"},
    {codigo: 1109nome:"Saia"tipo:"VE"},
    {codigo: 1112nome:"Vestido"tipo:"VE"}
  ];

  constructor(props) {
    super(props);
    this.state = {
      list: []
    };

    this.onOptionChange = this.onOptionChange.bind(this);
  }

  onOptionChange(item) {
    this.setState(state => {
      const list = state.list.concat(item);

      return {
        list
      };
    });
  }

  render() {
    return (
      <div className="App">
        <header className="App-header">
          <img src={logo} className="App-logo" alt="logo" />
          
          <div>
            Escolhidos:
            {this.state.list.toString()}
          </div>

          <div>
            Informática:
            <Lista lista={this.listaValores.filter(
function(item){ return item.tipo === 'PC'})} 
onOptionChange={this.onOptionChange} >
</Lista>
          </div>

          <div>
            Vestuário:
            <Lista lista={this.listaValores.filter(
function(item){ return item.tipo === 'VE'})} 
onOptionChange={this.onOptionChange} >
</Lista>
          </div>

        </header>
        
      </div>
    );
  }
}

export default App;

No componente "App" usamos o componente "Lista" duas vezes, uma com informações sobre informática e outra com informações sobre vestuário, sempre que o componente é usado a coleção de selecionados do pai é atualizada.

O código de exemplo pode ser encontrado aqui.

Comentários

Mais visitadas

Funções de data Oracle

  Com o Oracle é possível obter uma série de resultados a partir de uma ou mais datas, como por exemplo verificar o último dia do mês ou verificar a quantidade de meses entre duas datas, então vamos a alguns exemplos:   Data atual do sistema: SYSDATE Remover meses de uma data: ADD_MONTHS(SYSDATE, -1) Adicionar meses de uma data: ADD_MONTHS(SYSDATE, +1) Buscar o último dia do mês: LAST_DAY(SYSDATE) Primeiro dia do mês: TRUNC(SYSDATE, ‘MONTH’) Quantidade de meses entre duas datas: MONTHS_BETWEEN(SYSDATE, ‘27/07/1982’) Primeiro dia do ano: TRUNC(SYSDATE, ‘YEAR’) Dias da semana: DECODE( TO_NUMBER( TO_CHAR          (SYSDATE, ‘D’) ) ,1, ‘domingo’ ,2, ‘segunda-feira’ ,3, ‘terça-feira’ ,4, ‘quarta-feira’ ,5, ‘quinta-feira’ ,6, ‘sexta-feira’ ,7,’sábado’ )

Funções de Data e Hora (Delphi)

É muito comum nos depararmos no dia a dia com a necessidade de manipular datas e horas, seja para um calculo de permanência, dias de atraso enfim, é praticamente escapar de alguma situação que necessite desse tipo de controle. Assim como a necessidade e se utilizar algum recurso para manipular as datas e horas de alguma maneira e freqüente, as duvidas de como o faze-lo também é, basta um breve olhar em qualquer fórum especializado e lá está, alguma duvida relacionada, por isso decidi falar um pouco sobre uma unit muito poderosa chamada DateUtils para a manipulação de data e hora, com um grande numero de métodos e classes que facilitam a vida de qualquer um. Alguns exemplos: CompareDate(constA, B: TDateTime): TValueRelationship; Compara apenas a data de dois valores (do tipo TDateTime) retornando: LessThanValue O primeiro valor é menor que o segundo EqualsValue Os valores são iguais GreaterThanValue O primeiro valor é maior que o segundo CompareDateTime(const A, B: TD

Como Verificar se um Objeto Existe (Delphi)

Em alguns momentos surge a necessidade de verificar se um determinado objeto existe, ou seja se já foi criado, principalmente quando se trabalha com criação dinâmica em tempo de execução, então vamos ao exemplo: - Vamos criar uma variável, um vetor do tipo caixa de texto: var Minha_caixa : array of TEdit; - Em seguida definir o tamanho desse vetor, no caso será dez: setLength(Minha_caixa, 10) - Agora iremos criar nossa caixa de texto: // lembrando que o vetor inicia em zero // logo o índice final é o tamanho total - 1 for vl_i := 0 to Length(Minha_caixa) -1 do begin Minha_caixa[vl_i] := TEdit.Create(self); with Minha_caixa[vl_i] do begin Parent := Self; Name := 'Caixa_N'+IntToStr(vl_i); Text := 'Esta é a '+IntToStr(vl_i)+' º caixa !'; ReadOnly := true; Height := 21; Width :=