日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

react中使用高階函數

作者:海鷗-w 更新時間: 2023-07-13 編程語言

高階函數,
如果一個函數符合下面2個規范中的任何一個,那該函數就是高階函數
1.若A函數,接收的參數是一個函數,那么A就可以稱高階函數
2.若A函數,調用的返回值依然是一個函數,那么A就可以稱為高階函數
常見的高級函數有:Promise,setTimeout(()=>{}),map(()=>{})等等

<!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://blog.csdn.net/weixin_50379372/article/details/131641964

  • 上一篇:沒有了
  • 下一篇:沒有了
欄目分類
最近更新