React, 初见

何宏伟

React

[嵌牛导读]

作为前端爱好者,对于“前端”

又爱又恨, 无可奈何, 欲罢不能

作为React“初学者”,我不得不承认

React, This is really cool !

本文将从一个初学者的角度来探索,观察React,希望能够尝试用自己的角度去解读React.

[嵌牛鼻子]

React, 组件化(Component), 状态(state), 数据绑定,状态管理, VirtualDOM

[嵌牛提问]

  • 当你觉得你的代码组织简直不能直视, 当你觉得你的代码构思时逻辑清晰,可真正写出来一团糟,这个时候你得停下来,尝试着去解决为什么自己在用代码表达逻辑时是混乱的?
  • React如何能够获得如此青睐,为何具有如此魅力以至于不管项目大小都会去采用React
  • 当把React的思想运用在自己的项目中,会产生什么样的变化,是否会产生正向变化

[嵌牛正文]

React官方图标
1. MVC

MVC(Model, View, Controller),模型-视图-控制器.
对于MVC,存在两种观点:

  • MVC看作是一种设计模式
  • MVC是一种架构方式

我更倾向于后者。


MVC-图片来自网络
  • Model - 模型
    通常用于保存用户数据模型,或者数据库数据模型,负责处理或是管理数据逻辑
  • View - 视图
    通常用于构建视图来展示数据,负责显示来自Model建立的数据
  • Controller - 控制器
    通常被认为是Model 和 View 中间的传话者,接受来自View层的数据,传递给Model层更新数据,或是接受来自Model完成的数据 ,交付给View层来展示

之所以提到MVC,是因为React正是担任View层这一重要角色,用于构建页面动态UI。在接收到Controller传递的Model数据,通过动态建立组件(Component)组织,嵌套,生成页面。

2. React核心思想-组件化

组件Component,是React中非常重要的概念,因为最终生成的向用户展示的页面正是由许多个不同的组件,相互组合,嵌套,拼接而成

示例 - Src

如上图示例所示,页面组件化

整个页面 <Index />组件
顶部导航栏 <Nav />组件
中间搜索框 <Search />组件

最终页面构成(仅作示例说明)

<Index>
    <Nav />
    <Search />
<Index />

当我们在设计View层时,只需要构建这3个组件,进行组合即可。整个页面结构非常清晰明确,代码简洁便于维护阅读

这其实就是React带来的好处,它以一种高效的,易于理解的方式来构建页面,整个页面被分成各个不同的小块,每个小块就是一个组件(<Index /> | <Nav /> | <Search />),只需要将这些组件进行组合就可以高效的完成整个视图层的开发。

3. 状态(state)
class Clock extends React.Component {
  constructor() {
    super()
    this.state = {date: new Date()}; // state 与页面<h2>内容绑定
  }

  render() {
    return (
      <div>
        <h1>Hello, world!</h1>
        <h2>It is {this.state.date.toLocaleTimeString()}.</h2>
      </div>
    )
  }
}

React中页面有许多个组件构成,每一个组件有自己独立的数据(Model)需要展示,为了能够将数据变化能够及时的反应在视图层(View),React采用state 将数据绑定在页面,通过这种双向数据绑定可以完美解决数据和组件之间的完美同步

Model 变化  -〉 View变化
View变化   -〉 Model变化


END

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

推荐阅读更多精彩内容