非受控组件 使用ref来从 DOM 节点中获取表单数据 表单数据将交由 DOM 节点来处理
//非受控组件:先用先取
class Login extends React.Component {
getSubmit=()=>{
//阻止默认事件
event.preventDefault()
alert(`用户名:${this.ipt.value},密码:${this.iptT.value}`)
}
render() {
return (
<form action="https://developer.mozilla.org/" onSubmit={this.getSubmit}>
姓名:<input ref={(a)=>{this.ipt=a}} type="text" name="username"/>
密码:<input ref={(b)=>{this.iptT=b}} type="password" name="password"/>
<button>登录</button>
</form>
)
}
}
ReactDOM.render(<Login/>,document.getElementById("react"))
受控组件 表单组件的状态/数据只由state 维护 修改只能通过setState()来更新, 表单数据是由 React 组件来管理
//受控组件就是数据维护在状态state中,当需要用的时候直接从状态中取出
class Login extends React.Component {
//初始化状态
state={username:'', password:''}
//自定义赋值事件
getUserName=(event)=>{
const {username} =this.state
this.setState({username:event.target.value})
}
getPassWord=(event)=>{
const {password} =this.state
this.setState({password:event.target.value})
}
getSubmit=()=>{
//原生阻止默认事件
event.preventDefault()
const {password,username} =this.state
alert(`姓名${username},密码${password}`)
}
render() {
return (
<form onSubmit={this.getSubmit}>
姓名:<input onChange={this.getUserName} type="text" name="username"/>
<h2>{this.state.username}</h2>
密码:<input onChange={this.getPassWord} type="password" name="password"/>
<h2>{this.state.password}</h2>
<button>登录</button>
</form>
)
}
}
ReactDOM.render(<Login/>,document.getElementById("react"))
授控组件用高阶函数与函数柯里化写法
//高阶函数,如果一个函数符合下面2个规范中的任何一个,那该函数就是高阶函数
// 1.若A函数,接收的参数是一个函数,那么A就可以称高阶函数
// 2.若A函数,调用的返回值依然是一个函数,那么A就可以称为高阶函数
// 常见的高级函数有:Promise,setTimeout,map()等等
//函数的柯里化:通过函数调用继续返回函数的方式,实现多次接收参数最后统一处理的函数编码形式
class Login extends React.Component {
//初始化状态
state={username:'', password:''}
//自定义赋值事件 ,这块属于高阶函数,
getData=(data)=>{
// console.log(data) //username,password
// const {username,password} =data
return (event)=>{
//console.log("@") //onChange每改变一次,返回值的函数会被调用一次
return this.setState({
[data]:event.target.value
})
}
}
getSubmit=()=>{
//原生阻止默认事件
event.preventDefault()
const {username,password} =this.state
alert(`姓名${username},密码${password}`)
}
render() {
return (
<form onSubmit={this.getSubmit}>
{/*这块this.getData("username")加了(),onChange把getData函数的返回值作为回调,不加(),会把getData函数本身作为回调*/}
姓名:<input onChange={this.getData("username")} type="text" name="username"/>
<h2>{this.state.username}</h2>
密码:<input onChange={this.getData("password")} type="password" name="password"/>
<h2>{this.state.password}</h2>
<button>登录</button>
</form>
)
}
}
ReactDOM.render(<Login/>,document.getElementById("react"))
授控组件不用函数柯里化的写法
class Login extends React.Component {
//初始化状态
state={username:'', password:''}
getData=(datatest,e)=>{
this.setState({[datatest]:e})
}
getSubmit=()=>{
//原生阻止默认事件
event.preventDefault()
const {username,password} =this.state
alert(`姓名${username},密码${password}`)
}
render() {
return (
<form onSubmit={this.getSubmit}>
{/*这块this.getData("username")加了(),onChange把getData函数的返回值作为回调,不加(),会把getData函数本身作为回调*/}
姓名:<input onChange={(event)=>{return this.getData("username",event.target.value)}} type="text" name="username"/>
<h2>{this.state.username}</h2>
密码:<input onChange={event=>this.getData("password",event.target.value)} type="password" name="password"/>
<h2>{this.state.password}</h2>
<button>登录</button>
</form>
)
}
}
ReactDOM.render(<Login/>,document.getElementById("react"))