React学习总结(参考官方文档)

React学习总结

参考官方文档,整理一些应该被重视的知识点

React中的事件相关

  • 类似HTML中事件的使用方法,可以直接将事件处理函数作为属性值,赋给用驼峰式命名的事件属性。之后的事情交给React,React自己有一个事件系统,它可以保证事件在所有浏览器中的一致性
  • react知道如何去冒泡和捕获事件,这个实现是根据w3c的规范,不管使用的是什么浏览器

State相关

State 的异步工作方式

setState 方法本身是异步的,有一种常见的方式是当react数据改变时,通过 setState(data,callback) 这个方法会将新数据合并到this.state对象上,之后重新渲染组件。当组件结束了重新渲染(re-render),可选的第二个参数callback会被执行。

组件在什么时候需要State

大多数的组件应该简单的通过props获取数据,之后渲染组件,然而有时候会需要一些复杂的数据处理,比如说响应用户的操作,一个请求,此时需要用到state。但尽可能多的让组件无状态话,减少冗余。一种常见的模式是创建许多无状态的组件,它们仅仅负责渲染数据,有一个拥有状态组件在它们层级之上,经过一系列的逻辑处理,通过props将state传递给它的子组件。有状态的组件囊括了尽可能多的逻辑,而无状态的组件仅仅负责渲染数据。

哪些数据应该作为State

尽量使用 props 作为唯一的数据源,事件处理函数会响应用户的事件,此时可能会更新影响用户界面的数据,这些数据应该被 State 包含。真实环境下,这个数据应该很小且可以被 JSON 序列化 。
在创建包含状态的组件时,让它尽可能少的包含状态,并且将这些状态存入 this.state 对象中,后续的 render 方法再根据可能有的状态来计算出需要的其他数据,逻辑处理在 render ,通过状态来计算 render 的内容。

组件复用

React 因为新的 render 而导致 DOM 发生更新的过程称为组件校正,这个校正过程是根据组件的顺序决定,比如

// Render Pass 1
<Card>  
    <p>Paragraph 1</p>  
    <p>Paragraph 2</p>
</Card>
// Render Pass 2
<Card>  
    <p>Paragraph 2</p>   
</Card>

看起来像是 React 通过 diff 删除了第一个标签,但实际上 React 按照组件的顺序,修改了第一个标签的文本,删除了第二个组件。考虑一个组件由很多状态决定,内部的DOM需要来回的切换,由于组件校正的原理,可能会有些性能问题。此时可以选择为组件添加 display: none ,而不是直接选择删除。有些情况可能比较复杂,比如说有一个很长的列表,需要不断的重排序或者向首尾插入删除新子组件,这种情况如果按照顺序来校正,可能会出现性能问题,此时可以为这些子组件指定独一无二的key。当 React 校正这些组件的时候,就会直接重排序或者销毁,而不是按照顺序,修改子组件的内容来校正。

React.PropTypes

当项目越来越大,组件的复用越来越频繁,为了确保每次复用接收到的 props 是可用的,需要指定 propTypes

类似于 export,React.PropTypes 对象导出很多验证器,这些验证器可以保证传递来的 props 是正确的。
当一个不可用的值被传递给当前组件的 props,那么在控制台中就会显示异常。
具体的属性可以参考这个页面,可以为对象或者数组指定具体的内部 Child
http://facebook.github.io/react/docs/reusable-components.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,980评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,178评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,868评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,498评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,492评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,521评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,910评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,569评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,793评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,559评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,639评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,342评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,931评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,904评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,144评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,833评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,350评论 2 342

推荐阅读更多精彩内容

  • 原教程内容详见精益 React 学习指南,这只是我在学习过程中的一些阅读笔记,个人觉得该教程讲解深入浅出,比目前大...
    leonaxiong阅读 2,809评论 1 18
  • GUIDS 第一章 为什么使用React? React 一个提供了用户接口的JavaScript库。 诞生于Fac...
    jplyue阅读 3,508评论 1 11
  • 3. JSX JSX是对JavaScript语言的一个扩展语法, 用于生产React“元素”,建议在描述UI的时候...
    pixels阅读 2,804评论 0 24
  • 自己最近的项目是基于react的,于是读了一遍react的文档,做了一些记录(除了REFERENCE部分还没开始读...
    潘逸飞阅读 3,331评论 1 10
  • var obj={"a":"1","b":"2","c":"3"};//json对象 var arr=[];//新...
    西瓜炒苦瓜阅读 1,265评论 0 0