初识react

【转】react是一个js框架,类似于jquery,但是他做了很大的变化,它将利用jsx语法,将结构(html)和(js)合并在一起,这里会有人好奇,好不容易分离的,为什么又和在一起了呢,这是因为用脚本操作dom的代价很昂贵,有个贴切的比喻,把DOM和JavaScript各自想象为一个岛屿,它们之间用收费桥梁连接,js每次访问DOM,都要途径这座桥,并交纳“过桥费”,访问DOM的次数越多,费用也就越高。 因此,推荐的做法是尽量减少过桥的次数,努力待在ECMAScript岛上。因为这个原因react的虚拟dom就显得难能可贵了,它创造了虚拟dom并且将它们储存起来,每当状态发生变化的时候就会创造新的虚拟节点和以前的进行对比,让变化的部分进行渲染。整个过程没有对dom进行获取和操作,只有一个渲染的过程,所以react说是一个ui框架

1.react组件化

react组件很明显由dom视图和state数据组成,state的状态决定着视图的状态,这和mvc的开发有着区别,react只负责ui的渲染,react只根据setState来控制试图的更新,setState会自动调用render函数,触发试图的重新渲染,组件就是拥有独立功能的视图模块,许多小的组件合并成一个大的组件,而整个页面也就是由不同的组件合并而成,当我们是使用组件<Hello/>其实是对class Hello的实例化,相当于new Hello()这里有三点需要注意1.组件的名字需要大写是为了区别html自己的标签,也可以说成是区别内置组件2.由于es6中的class成为类的关键字,所以样式部分class改为className 3.类和模块内部均采用严格模式,所以不需要指定use strict 运行模式

2.react中的diff算法

当组件更新时候,react会创建一个新的虚拟dom,并且会和之前存储的dom进行比较,这个比较就是运用的diff算法,所以组件的初始化使用不到该算法,react提出一种假设,相同的节点具有类似的结构,不同的节点具有不同的结构,在这种假设上进行逐层的比较,如果发信啊对应的结点是不同的,就直接删除原来的节点以及该节点包含的所有子节点,然后替换成新节点,如果是新节点则进行属性的更改,而patch算法就是进行修改的算法

3.组件的生命周期


理解该图很重要,也就大致理解了react的工作原理,当我们声明一个组件,首先进行组件的初始化工作,也就是在构造函数中,将该有的数据初始化(state),componentWillMount()组件初始化时只调用,以后组件更新不调用,整个生命周期只调用一次,此时可以修改state,然后 render()react最重要的步骤,创建虚拟dom,进行diff算法,更新dom树都在此进行。此时就不能更改state了,componentDidMount(),组件渲染之后调用,可以通过this.getDOMNode()获取和操作dom节点,只调用一次,shouldComponentUpdate(nextProps, nextState)react性能优化非常重要的一环。组件接受新的state或者props时调用,我们可以设置在此对比前后两个props和state是否相同,如果相同则返回false阻止更新,因为相同的属性状态一定会生成相同的dom树,这样就不需要创造新的dom树和旧的dom树进行diff算法对比,节省大量性能,尤其是在dom结构复杂的时候。不过调用this.forceUpdate会跳过此步骤,componentWillUnmount()组件将要卸载时调用,一些事件监听和定时器需要在此时清除

4.react-router路由

Router就是React的一个组件,它并不会被渲染,只是一个创建内部路由规则的配置对象,根据匹配的路由地址展现相应的组件,Route则对路由地址和组件进行绑定,点击页面切换的过程变为当我点击link标签,会先发生url的地址改变,当router监听到地址改变,就会根据route中的path去找匹配然后跳转到相应的component,另一个就是单页面应用,当点击一个按钮切换到另一个部分应用的时候平时是需要向后台发送数据,然后前台获得数据操作dom,而react-router只是按需加载相应的js文件到页面中

5.组件之间的通信

react推崇单项数据流,自上而下进行数据的传递如果是父->子,直接调用props属性,如果是子->父则需要在父组件上设置回调函数当作属性传递给儿子,儿子直接调用函数从而和父组件通信,而兄弟之间无法直接通信,他们只能利用同一层的上级作为中转,状态提升,传递信息

6.redux(这个目前还没用到,啊哈哈,先把解释贴着,留给日后)


注原文:https://github.com/bailicangdu/react-pxq

1.关于react的思考

2.react几个你可能疑惑点

3.react源码解析(组件声明与初始化)

4. react源码解析(组件的挂载)

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

推荐阅读更多精彩内容