高阶函数,
如果一个函数符合下面2个规范中的任何一个,那该函数就是高阶函数
1.若A函数,接收的参数是一个函数,那么A就可以称高阶函数
2.若A函数,调用的返回值依然是一个函数,那么A就可以称为高阶函数
常见的高级函数有:Promise,setTimeout(()=>{}),map(()=>{})等等文章来源地址https://www.toymoban.com/news/detail-548566.html
<!DOCTYPE html>
<html>
<body>
<div id="react"> </div>
<!--准备好一个容器-->
<div id="test"></div>
<!--引入react核心库,核心库必须先引入-->
<script type="text/javascript" src="./js/react.development.js"></script>
<!--引入react-dom, 用于支持react操作DOM-->
<script type="text/javascript" src="./js/react-dom.development.js"></script>
<!--引入babel,用于将jsx转为js-->
<script type="text/javascript" src="./js/babel.min.js"></script>
<!-- 引入prop-types,用于对组件标签属性进行限制 -->
<script type="text/javascript" src="./js/prop-types.js"></script>
<div id="react"></div>
<script type="text/babel">
//函数的柯里化:通过函数调用继续返回函数的方式,实现多次接收参数最后统一处理的函数编码形式
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"))
</script>
<style>
.spacing {
margin: 15px;
}
</style>
</body>
</html>
文章来源:https://www.toymoban.com/news/detail-548566.html
到了这里,关于react中使用高阶函数的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!