React 学习笔记(一)[从JSX到Virtual DOM]

最近尝试使用React做一个小项目(todolist),现在虽然做完了,但其实代码的实现实在是烂透了,比如leancloud的数据获取、另外由于组件划分设计得有点怪,而且页面的交互细节太依赖数据,数据的传递及管理并不如人意,很多时候要经过中间层,这让我感觉很别扭,以至于萌生加入redux来优化这个项目的念头。
这次会先充分了解react及redux的机制,再来完成项目。

react 与 JSX

在我刚使用react的时候,最鲜明的特征应该就是可以在js里写“HTML”了,这其实就是JSX,而且这写看似HTML的字符串也并不是HTML

  • 什么是JSX

    JSX是一种类XML语言,全称是JavaScript XML,它是对javaScript的一种扩展。
    在react里,我们可以用JSX直观地定义出一个UI组件的结构,当然其实我们也可以不用JSX来写,因为最终JSX也会经过转义,成为一个描述DOM结构的对象

    但 react作者 还是强烈建议我们使用JSX,原因上面也有说---直观。简明的代码结构更利于开发和维护,JSX的特点能让我们在构建复杂的树形结构时比函数调用和对象字面量更易读。

    点这里体验JSX

    //使用JSX
    class Sayhi extends React.Component{
      render(){
        return(
          <div>
            <div>
              <h1>hello World</h1>
              <p> I am description</p>
            </div>
         </div>
        )
      }
    }
    ReactDom.render(<Sayhi/>,document.getElementById('root'))
    
    // 不使用JSX
    
    class Sayhi extends React.Component{
      render(){
        return(
          React.createElement(
          "div",
          null,
            React.createElement(
              "div",
              null,
              React.createElement(
                "h1",
                null,
                "hello World"
              ),
              React.createElement(
                "p",
                null,
                " I am description"
              ) 
            )
          )
        )
      }
    }
    ReactDom.render(<Sayhi/>,document.getElementById('root'))
    
  • JSX使用要记

    1.所有的标签都需要闭合。

    2.自定义组件的声明变量采用首字母大写

    3.JSX内表达式需用{}包起来

    4.比较特殊的属性如class在JSX里需写成className

    5.每段JSX里的XML只能有一个根元素

JSX与 Virtual DOM

上面讲到JSX最终会被编译为一个描述DOM结构的对象,这里就引出了一个React的重要思想----Virtual DOM。

我们都知道真实的DOM并不是JavaScript的内置对象,而是浏览器提供给我们的接口。而React中的Virtual DOM是存在于内存的,显而易见,让JavaScript操作内存比操作DOM节点快得多。react就是利用Virtual DOM来减少对实际DOM的操作从而提升性能。

react通过diff算法,对比虚拟DOM变化前后的变化,来进行局部更新。比较特殊的是:传统的diff算法时间复杂度为O(n^3),而React的时间复杂度是O(n),这样的设置提高了React的性能,但是不可避免地会带来一定的代价。
举一个栗子


上面两个树行结构的DOM是变化前后的结构,其中A从father的子元素变为B的子元素,在react的diff算法中,它是无法辨认这种变化的,它会认为A从页面结构中卸载了,而新的DOM结构内的A是新的组件元素。
1.不可缺少的key
因此日常开发中,我们动态生成元素的时候,需要给每个元素带上一个key,这也是为了给每个元素带上一个唯一的标记,便于react识别。
而我们动态生成元素大多数都是通过map一个数组,这里就很喜欢给每个元素的key标记为他们的index,其实这样是不对的做法,我们不能保证这个数组不会临时增加或者减少一个节点,这个时候每个元素的key也会发生变化,那么我们建立这个key的意义将不存在了,所以,key还要是稳定的
[注:上面的例子比较极端,React官方也不建议DOM节点跨层级的操作]
2.占位的组件
先来一段代码

this.state.isCompleted?<Completed> : null

这段代码通过一个变量来控制组件的出现或消失,这种情况不需要加一个key来辨别,因为这里已经有null<Completed>占位了。
3.组件对比
对于组件变化前后的对比策略,react会首先对比俩组件的类型,如果类型一致,则继续对比其他内容;若类型不一致,则判断该组件为dirty component,然后替换整个组件(包括它的子节点)

最后,本人才疏学浅,所记录的笔记仅仅是为了巩固记忆,加深印象,难免有点肤浅,望见谅。

参考资料
react深入浅出之JSX与组件
react的diff运算
Morgan大神--进击的React专栏

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

推荐阅读更多精彩内容

  • 3. JSX JSX是对JavaScript语言的一个扩展语法, 用于生产React“元素”,建议在描述UI的时候...
    pixels阅读 2,806评论 0 24
  • 参考文章:深度剖析:如何实现一个Virtual DOM 算法 作者:戴嘉华React中一个没人能解释清楚的问题——...
    waka阅读 5,952评论 0 21
  • 本文译自《Optimizing React: Virtual DOM explained》,作者是Alexey I...
    YuyingWu阅读 7,857评论 0 17
  • 原教程内容详见精益 React 学习指南,这只是我在学习过程中的一些阅读笔记,个人觉得该教程讲解深入浅出,比目前大...
    leonaxiong阅读 2,810评论 1 18
  • 泰山之巅 一位少年一把剑 少年问剑 可愿随我踏遍红尘 剑曰 有君在,便有魂 转载数十年 走遍大江南北 一人一剑 所...
    乔边故事阅读 358评论 0 1