Como seleciono determinadas barras no react.js?
Este é o meu código:
var Progressbar = React.createClass({
getInitialState: function () {
return { completed: this.props.completed };
},
addPrecent: function (value) {
this.props.completed += value;
this.setState({ completed: this.props.completed });
},
render: function () {
var completed = this.props.completed;
if (completed < 0) { completed = 0 };
return (...);
}
Eu quero usar este componente React:
var App = React.createClass({
getInitialState: function () {
return { baction: 'Progress1' };
},
handleChange: function (e) {
var value = e.target.value;
console.log(value);
this.setState({ baction: value });
},
handleClick10: function (e) {
console.log('You clicked: ', this.state.baction);
document.getElementById(this.state.baction).addPrecent(10);
},
render: function () {
return (
<div class="center">Progress Bars Demo
<Progressbar completed={25} id="Progress1" />
<h2 class="center"></h2>
<Progressbar completed={50} id="Progress2" />
<h2 class="center"></h2>
<Progressbar completed={75} id="Progress3" />
<h2 class="center"></h2>
<span>
<select name='selectbar' id='selectbar' value={this.state.baction} onChange={this.handleChange}>
<option value="Progress1">#Progress1</option>
<option value="Progress2">#Progress2</option>
<option value="Progress3">#Progress3</option>
</select>
<input type="button" onClick={this.handleClick10} value="+10" />
<button>+25</button>
<button>-10</button>
<button>-25</button>
</span>
</div>
)
}
});
Quero executar a função handleClick10 e executar a operação para minha barra de progresso selecionada. Mas o resultado que recebo é:
You clicked: Progress1
TypeError: document.getElementById(...) is null
Como seleciono o elemento certo em react.js?
fonte
Para obter o elemento,
react
você precisa usarref
e dentro da função, você pode usar oReactDOM.findDOMNode
métodoMas o que eu mais gosto de chamar é o árbitro dentro do evento
Este é um bom link para ajudá-lo a descobrir.
fonte
this.myTextInput
para acessar.React.findDOMNode
me dáreact__WEBPACK_IMPORTED_MODULE_0___default.a.findDOMNode is not a function
React.findDOMNode
no modo estrito.Você pode substituir
com
fonte
Como o React usa o código JSX para criar um HTML, não podemos nos referir a métodos de regulação como documment.querySelector ou getElementById.
Em vez disso, podemos usar o sistema React ref para acessar e manipular o Dom, como mostrado no exemplo abaixo:
}
fonte