react学习——13react高阶函数_函数柯里化

1、高阶函数柯里化实现

javascript 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!--    移动端适配-->
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>1_高阶函数_函数柯里化.html</title>
</head>
<body>
<!--准备一个容器-->
<div id="root"></div>
<!--引入react核心库-->
<script type="text/javascript" src="../js/react.development16.3.1.js"></script>
<!--引入react-dom.js库,用于支持react操作DOM-->
<script type="text/javascript" src="../js/react-dom.development16.3.1.js"></script>
<!--引入babel,用于jsx的转换jsx-->
<script type="text/javascript" src="../js/babel.min.js"></script>
<script type="text/babel">/*此处一定要写babel*/
    class Demo extends React.Component{
        //#region
        /*
            高阶函数:如果一个函数符合下面2个规范中的任何一个,那么这个函数就是一个高阶函数
                1.若A函数,接收的参数是一个函数,那么A就是一个高阶函数
                2.若A函数,调用的返回值是一个函数,那么A就是一个高阶函数
                常见的高阶函数有:
                promise、setTimeout、arr.map()等等
            函数的柯里化:通过函数调用继续返回函数的方式,实现多次接收参数最后统一的函数编码形式。
         */
        //#endregion

        state = {
            username:'',//用户名
            password:''//密码
        }
        //保存数据
        saveFormData=(type)=>{
            return (event)=>{
                console.log("=="+type,event.target.value)
                this.setState({
                    [type]:event.target.value
                })
            }
        }
        handleSubmit=(event)=>{
            event.preventDefault();//阻止表单提交
            const {username,password} = this.state
            alert(`你输入的用户名是:${username},密码是:${password}`)
        }
        render(){
            return(
                <form onSubmit={this.handleSubmit}>
                    用户名:<input onChange={this.saveFormData('username')}  type="text" name="username"/>
                    密码:<input onChange={this.saveFormData('password')} type="password" name="password"/>
                    <button>点击登录</button>
                </form>
                )
        }
    }
    ReactDOM.render(<Demo/>,document.getElementById('root'))
</script>
</body>
</html>

2、不用柯里化实现

javascript 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!--    移动端适配-->
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>2_不用柯里化实现.html</title>
</head>
<body>
<!--准备一个容器-->
<div id="root"></div>
<!--引入react核心库-->
<script type="text/javascript" src="../js/react.development16.3.1.js"></script>
<!--引入react-dom.js库,用于支持react操作DOM-->
<script type="text/javascript" src="../js/react-dom.development16.3.1.js"></script>
<!--引入babel,用于jsx的转换jsx-->
<script type="text/javascript" src="../js/babel.min.js"></script>
<script type="text/babel">/*此处一定要写babel*/
    class Demo extends React.Component{
        //#region
        /*
            高阶函数:如果一个函数符合下面2个规范中的任何一个,那么这个函数就是一个高阶函数
                1.若A函数,接收的参数是一个函数,那么A就是一个高阶函数
                2.若A函数,调用的返回值是一个函数,那么A就是一个高阶函数
                常见的高阶函数有:
                promise、setTimeout、arr.map()等等
            函数的柯里化:通过函数调用继续返回函数的方式,实现多次接收参数最后统一的函数编码形式。
         */
        //#endregion

        state = {
            username:'',//用户名
            password:''//密码
        }
        //保存数据
        saveFormData=(type,event)=>{
            this.setState({
                [type]:event.target.value
            })
        }
        handleSubmit=(event)=>{
            event.preventDefault();//阻止表单提交
            const {username,password} = this.state
            alert(`你输入的用户名是:${username},密码是:${password}`)
        }
        render(){
            return(
                <form onSubmit={this.handleSubmit}>
                    用户名:<input onChange={event=>this.saveFormData('username',event)}  type="text" name="username"/>
                    密码:<input onChange={event=>this.saveFormData('password',event)} type="password" name="password"/>
                    <button>点击登录</button>
                </form>
                )
        }
    }
    ReactDOM.render(<Demo/>,document.getElementById('root'))
</script>
</body>
</html>
相关推荐
weixin_395772472 分钟前
计算机网络学习笔记】初始网络之网络发展和OSI七层模型
笔记·学习·计算机网络
弓.长.9 分钟前
ReactNative for OpenHarmony项目鸿蒙化三方库:react-native-svg(CAPI) — 矢量图形组件
react native·react.js·harmonyos
军军君0116 分钟前
Three.js基础功能学习十五:智能黑板实现实例二
开发语言·前端·javascript·vue.js·3d·threejs·三维
南境十里·墨染春水17 分钟前
linux学习进展 进程的内存管理
linux·服务器·学习
小陈phd23 分钟前
多模态大模型学习笔记(三十四)——ChatTTS:新一代中文语音合成工具原理与实战解析
笔记·学习·语音识别
四千岁38 分钟前
Ollama+OpenWebUI 最佳组合:本地大模型可视化交互方案
前端·javascript·后端
写不来代码的草莓熊40 分钟前
el-date-picker ,自定义输入数字自动转换显示yyyy-mm-dd HH:mm:ss格式
前端·javascript·vue.js
zhangrelay42 分钟前
面向机器人工程的 Linux 发行版:科学选型与深度评测-2026
笔记·学习
局i1 小时前
从零搭建 Vite + React 项目:从环境准备到干净项目的完整指南
前端·react.js·前端框架
Wect1 小时前
JS手撕:手写Koa中间件与Promise核心特性
前端·javascript·面试