Par exemple: codepen
var InputBox = React.createClass({
render: function() {
return (
<input className="mainInput" value='Some something'></input>
)
}
});
javascript
select
input
reactjs
Alexander Shtang
la source
la source
<input type='text' value='Some something' onFocus={e => e.target.select()} />
disabled
zone de texte? jsfiddle.net/69z2wepo/317733disabled
, utilisezreadOnly
: jsfiddle.net/kxgsv678var InputBox = React.createClass({ getInitialState(){ return { text: '' }; }, render: function () { return ( <input ref="input" className="mainInput" placeholder='Text' value={this.state.text} onChange={(e)=>{this.setState({text:e.target.value});}} onFocus={()=>{this.refs.input.select()}} /> ) } });
Vous devez définir ref sur l'entrée et lorsque vous vous concentrez, vous devez utiliser select ().
la source
Merci, je l'apprécie. Je l'ai fait ainsi:
var input = self.refs.value.getDOMNode(); input.focus(); input.setSelectionRange(0, input.value.length);
la source
Dans mon cas, je voulais sélectionner le texte depuis le début après l'apparition de l'entrée dans le modal:
componentDidMount: function() { this.refs.copy.select(); }, <input ref='copy'
la source
var React = require('react'); var Select = React.createClass({ handleFocus: function(event) { event.target.select() }, render: function() { <input type="text" onFocus={this.handleFocus} value={'all of this stuff'} /> } }); module.exports = Select;
Sélection automatique de tout le contenu d'une entrée pour une classe de réaction. L'attribut onFocus sur une balise d'entrée appellera une fonction. La fonction OnFocus a un paramètre appelé événement généré automatiquement. Comme indiqué ci-dessus, event.target.select () définira tout le contenu d'une balise d'entrée.
la source
Un autre composant fonctionnel avec useRefHook:
const inputEl = useRef(null); function handleFocus() { inputEl.current.select(); } <input type="number" value={quantity} ref={inputEl} onChange={e => setQuantityHandler(e.target.value)} onFocus={handleFocus} />
la source