zoukankan      html  css  js  c++  java
  • React学习笔记

    事件处理和参数合成

    React里只需要把事件处理器以驼峰形式命名当作组件的props传入即可。React内部创建一套合成事件系统来使所有事件在IE8以上的浏览器表现一致。也就是说,React知道如何冒泡和捕获事件,而且你的事件处理器接收到的参数和W3C规范一致,无论你使用哪种处理器。

    幕后原理:自动绑定( Autobinding )和事件代理( Event Delegation )

    自动绑定:在JavaScript创建回调的时候,为了保证 this 的正确性,一般都需要显式的绑定方法到它的实例上。在React中,所有方法都被自动绑定到它的组件实例上。React还缓存这些方法,所以CPU和内存都是非常高效。

    事件代理:React实际上并没有把事件处理器绑定到节点本身。当React启动时,它在最外层使用唯一一个事件监听器处理所有事件。当组件被加载和卸载时,只是在内部添加或删除事件处理器。当事件触发时,React根据映射决定如何分发。当映射没有事件处理器时,会当作空处理。

    state工作原理

    常用的通知Reacts数据变化的方法是调用 setState(data,callback) 。这个方法会合并data到 this.state 中,并重新渲染组件。尝试把尽可能多的组件无状态化。常用的模式是创建多个只负责渲染数据的无状态组件,在它们的上层创建一个有状态组件并把它的状态通过props传给子级。这个有状态的组件封装了所有用户的交互逻辑,而这些无状态的组件则负责声明式的渲染数据。

    在需要用户输入时、服务请求时、时间变化等做出响应时,使用state。
    创建一个状态化的组件时,思考表示它的状态最少需要哪些数据,并只把这些数据存入 this.state

    数据流

    React里,数据通过从上面介绍的 props 从拥有者流向归属者。这就是高效的单向数据绑定;拥有者们通过它们的 propsstate 计算出一些值,并把这些值绑定到它们拥有的的组件的props上。因为这个过程会递归的调用,所以数据变化会自动在所有它们被使用的地方反映出来。

    Mixins

    组件是React复用代码的最佳方式,但有时一些不同的组件间也需要共用一些功能。有时会被成为跨切面关注点。React使用 mixins 来解决这类问题。

    受控组件

    受控组件:一个受控的组件有一个 value prop。渲染一个受控 <input> 会反映 value prop的值。所以在这个例子中,我们更接受用户提供的值来更新 input 组件的 value prop。
    不受控组件:一个没有 value 属性的 <input> 是一个不受控的组件。不受控组件维持自己的内部状态。

    使用React的流程

    • 从模型 (mock) 开始
    • 把UI拆分为一个组件的层级
    • 用React创建一个静态的版本

      要构建一个静态版本app来渲染你的模型,你将会想到构建一个重用其它组件并利用props传递数据的组件。props是一种从父级传递数据到子级的方式。 State 仅仅是为互动性,也就是随着时间变化的数据锁预留的。

    • 确定最小(但完备)的 UI state 表达
    • 确定你的state应该存放在于哪里
    • 添加反向数据流

    确定哪些组件可以改变或拥有state

    • 确定哪些组件基于 state 来渲染内容
    • 找到一个共同的拥有者组件(在所有需要这个state组件的层次之上,找出共有的单一组件)。
    • 要么是共同拥有者,要么是在其它层级里更高级的组件应该拥有这个state
    • 如果你不能找到一个组件可以让其有意义的拥有这个 state ,可以简单地创建一个新的组件 hold 住这个 state ,并把它添加到比共同拥有组件更高的层级上。




  • 相关阅读:
    szoj657 【AHSDFZNOI 7.2 WuHongxun】Odd
    cogs2652 秘术「天文密葬法」
    bzoj1026 [SCOI2009]windy数
    bzoj1862/1056: [Zjoi2006]GameZ游戏排名系统
    java-PreparedStatement的用法
    java-JDBC登录注册代码
    java-String Date Calendar之间的转换
    java-如何用eclipse打包jar
    java-通过JDBC操作数据库
    java-JDBC配置驱动程序
  • 原文地址:https://www.cnblogs.com/fengmanlou/p/1de352804383c4e99845ef5b17da8c30.html
Copyright © 2011-2022 走看看