提问人:Vana 提问时间:7/19/2017 更新时间:3/21/2019 访问量:16489
使用 react-bootstrap 获取输入文本的值
Get value of input text with react-bootstrap
问:
我尝试将值放入输入文本中,并使用 react-bootstrap 将其添加到文本区域。
我知道我必须使用 ReactDOM.findDOMNode 来获取带有 ref 的值。我不明白出了什么问题。
这是我的代码:
import React from 'react';
import logo from './logo.svg';
import ReactDOM from 'react-dom';
import { InputGroup, FormGroup, FormControl, Button} from 'react-bootstrap';
import './App.css';
class InputMessages extends React.Component {
constructor(props) {
super(props);
this.handleChange = this.handleChange.bind(this);
this.GetMessage= this.GetMessage.bind(this);
this.state = {message: ''};
}
handleChange(event)
{
this.setState({message: this.GetMessage.value});
}
GetMessage()
{
return ReactDOM.findDOMNode(this.refs.message );
}
render() {
var message = this.state.message;
return(
<FormGroup >
<FormControl
componentClass="textarea" value={message} />
<InputGroup>
<FormControl type="text" ref='message' />
<InputGroup.Button>
<Button bsStyle="primary" onClick={this.handleChange}>Send
</Button>
</InputGroup.Button>
</InputGroup>
</FormGroup>
);
}
}
export default InputMessages;
答:
3赞
Fawaz
7/19/2017
#1
将输入引用添加到表单中:
<FormControl inputRef={ref => { this.myInput = ref; }} />
所以现在你得到的值是这样的
this.myInput.value
评论
0赞
Vana
7/21/2017
它有效,但我将值存储在状态中。我想将其存储到变量中。我使用 2 个组件,所以我无法将 this.myinput.value 写入其他组件
1赞
Vana
7/21/2017
<FormControl > componentClass=“textarea” value={this.input.value} /> 不识别 ref,而函数可以
6赞
naribo
3/21/2019
#2
Form Control 有一个 prop,它允许我们使用 React Refsref
示例代码:
class MyComponent extends React.Component {
constructor() {
/* 1. Initialize Ref */
this.textInput = React.createRef();
}
handleChange() {
/* 3. Get Ref Value here (or anywhere in the code!) */
const value = this.textInput.current.value;
}
render() {
/* 2. Attach Ref to FormControl component */
return (
<div>
<FormControl ref={this.textInput} type="text" onChange={() => this.handleChange()} />
</div>
)
}
}
希望这有帮助!
评论
0赞
Sara Inés Calderón
7/3/2019
很有帮助!谢谢!!
评论
[<>]