React.JS概念介绍

概念

React.js 是 Facebook 推出的一个用来构建用户界面的 JavaScript 库。

React只有很少的API,这使得它很容易去学习与理解。当然,使用它也是相当有意思的。但是,简约却并不简单。在我们开始之前,有一些概念是需要去理解的。

React元素(React elements)

React元素是用于呈现HTML结构的JavaScript对象。它们不会存在于浏览器中,只是用于描述浏览器中的元素,比如h1div 或者 section等等。

模块(Components)

模块是开发者创建的React元素。它们通过比用户界面的范围要大,因为它们同时包含了其结构与功能。想像一下导航栏,点赞按钮,图片上传这些模块的概念。

JSX

JSX是一种用于创建React元素和模块的技术,或者说是规范、语言。比如 <h1>Hello</h1> 便是一个用JSX所写的React元素。同样的React元素,可以用原生的JavaScript实现,即React.DOM.h1(null, ‘Hello‘);。相比原生的JavaScript,JSX更加简洁。会让你花更少的精力去读和写代码,在上线的时候将其转换成原生的JavaScript即可。

虚拟DOM(Virtual DOM)

虚拟DOM是一个JavaScript的树形结构,包含了React元素和模块。React通过渲染虚拟DOM到浏览器,使得用户界面得以显示。React也会观察虚拟DOM的变化,根据虚拟DOM自动地改变浏览器DOM元素。

了解了这些概念之后,我们就可以畅快地敲React代码了。这里将会创建一系列的用户界面,每一个界面都将提前添加一层功能层。我们会做一个类似instagram的应用 - 当然,这个很粗糙。

渲染(Rendering)

业务的第一步是渲染一个虚拟的元素(React元素或者模块都可以)。由于每一个虚拟元素都存在于内存之中,所以我们必须显式地告诉React,将其渲染到浏览器的DOM之中。

React.render(<img src=‘http://img.phperz.com/data/img/20150203/1422932962_6713.jpg‘ />, document.body);

render 函数接受两个参数,一个是虚拟元素,一个是真实的DOM节点。React就是获取到虚拟元素之后,将其插入到所给的节点之中。此时,在浏览器中便可以看到照片了。

模块(Components)

模块是React的核心与灵魂。它们可以自定义React元素。经常由单一的功能或者结构扩展而来。

var Photo = React.createClass({

  render: function() {    return <img src=‘http://img.phperz.com/data/img/20150203/1422932962_6713.jpg‘ />
  }
});

React.render(<Photo />, document.body);

createClass 函数接受一个对象,该对象实现了render 的函数。
这个Photo模块被构建好,<Photo />,然后渲染到document body中。
该模块并没有比上一个React图像元素做更多的事情,但这却更加有利于在功能和结构上进行扩展。

属性(Props)

属性可以认为是模块的一些配置选项。它们以参数(arguments)的形式传递给模块,看起来就像HTML的属性(attributes)。

var Photo = React.createClass({

  render: function() {
    return (      <div className=‘photo‘>
        <img src={this.props.imageURL} />
        <span>{this.props.caption}</span>
      </div>
    )
  }
});

React.render(<Photo imageURL=‘http://img.phperz.com/data/img/20150203/1422932962_6713.jpg‘ caption=‘Headset‘ />, document.body);

render 函数里面,两个属性(props)传到了Photo模块,imageURL 和 captionimageURL属性被用作React元素中的src。而caption属性则以纯文本的方式在React中的span元素使用。

值得一提的是,模块永远不应该去改变属性的的值,它们是不可变的。如果一个模块有一个可变的数据,那应该应用使用状态对象(state object)。

状态(State)

状态对象是一个模块的内部对象。它会持有可变的数据。

var Photo = React.createClass({  toggleLiked: function() {    this.setState({      liked: !this.state.liked
    });
  },  getInitialState: function() {    return {      liked: false
    }
  },  render: function() {    var buttonClass = this.state.liked ? ‘active‘ : ‘‘;    return (
      <div className=‘photo‘>
        <img src={this.props.src} />

        <div className=‘bar‘>
          <button onClick={this.toggleLiked} className={buttonClass}>
            ?
          </button>
          <span>{this.props.caption}</span>
        </div>
      </div>
    )
  }
});

React.render(<Photo src=‘http://img.phperz.com/data/img/20150203/1422932962_6713.jpg‘ caption=‘Headset‘/>, document.body);

在模块中引入状态,会增加一点点的复杂度。

在这模块中,有一个新的函数getInitialState。当模块初始化的时候,React会调用这个函数。而返回的对象则作为React的初始化状态(看函数名就知道)。
还有一个新的函数叫toggleLiked。这个函数调用了模块上的setState方法,可以改变状态liked的值。
通过模块的render函数,变量buttonClass被赋值成了‘active‘或者空,这都依赖于liked状态。
buttonClass是React按钮元素的class名字。按钮还拥有一个onClick的事件回调,指向toggleLiked函数。

当模块渲染成浏览器DOM的时候,究竟发生全过程:

  • 当按钮点击被触发时,调用了toggleLiked
  • liked的状态被改变
  • React将模块再次渲染成虚拟DOM
  • 新的虚拟DOM与旧的虚拟DOM相比较
  • React将改变的部分隔离,然后更新到浏览器DOM

在这个场景中,React会改变button上的类名。

组合(Composition)

组合的意思是说,将小的分散的模块组成一个大的整体。比如Photo模块可以在PhotoGallery中使用:

var Photo = React.createClass({

  toggleLiked: function() {
    this.setState({
      liked: !this.state.liked
    });
  },

  getInitialState: function() {    return {
      liked: false
    }
  },

  render: function() {    var buttonClass = this.state.liked ? ‘active‘ : ‘‘;    return (
      <div className=‘photo‘>
        <img src={this.props.src} />

        <div className=‘bar‘>
          <button onClick={this.toggleLiked} className={buttonClass}>
            ?
          </button>
          <span>{this.props.caption}</span>
        </div>
      </div>
    )
  }
});var PhotoGallery = React.createClass({

  getDataFromServer: function() {    return [{
      url: ‘http://img.phperz.com/data/img/20150203/1422932962_6713.jpg‘,
      caption: ‘Headset‘
    },
    {
      url: ‘http://owenyang0.github.io/images/mocha.png‘,
      caption: ‘Mocha‘
    },
    {
      url: ‘http://owenyang0.github.io/images/catalog.png‘,
      caption: ‘Catelog‘
    }];
  },

  render: function() {    var data = this.getDataFromServer();    var photos = data.map(function(photo) {      return <Photo src={photo.url} caption={photo.caption} />
    });    return (
      <div className=‘photo-gallery‘>
        {photos}
      </div>
    )
  }
});

React.render(<PhotoGallery />, document.body);

这个Photo模块完完全全和上面的一样。但新的PhotoGallery模块会生成Photo模块。该场景中,伪造了返回包含三个对象的数组的数据,每一个对象都返回一个url和其标题。通过循环,生成了三个Photo的模块,将最终的返回值插入到render函数之中。

小结

用React来构建你的用户界面,我想这也差不多了。React的文档手册,包含了所有的细节。强烈推荐大家去读一下。

时间: 2024-10-11 12:59:57

React.JS概念介绍的相关文章

學習 React.js:用 React.js 和 Flux 創建一個簡單的購物車

Creating A Simple Shopping Cart with React.js and Flux Ken Wheeler (@ken_wheeler) 簡介 歡迎來到學習 React 的第四章這也是最後一章!到現在,我們已經學習了怎樣利用 React 的 API 來創建狀態型組件,如何應用它們,以及如何運用臉書的 Flux 架構來工作的 今天我們將把所有的這一切放到一塊,來創建一個簡單的購物車應用.在現在的電商網站上,產品的詳細頁面相互依賴,而 React 有助於簡化並有效的組織它們

在Node.js上搭建React.js开发环境

1.React.js的介绍: React 是一个用于构建用户界面的 JAVASCRIPT 库. React主要用于构建UI,很多人认为 React 是 MVC 中的 V(视图). React 起源于 Facebook 的内部项目,用来架设 Instagram 的网站,并于 2013 年 5 月开源. React 拥有较高的性能,代码逻辑非常简单,越来越多的人已开始关注和使用它. 特点: 1.声明式设计 ?React采用声明范式,可以轻松描述应用. 2.高效 ?React通过对DOM的模拟,最大限

MVC、MVP、MVVM、Angular.js、Knockout.js、Backbone.js、React.js、Ember.js、Avalon.js 概念摘录

转自:http://www.cnblogs.com/xishuai/p/mvc-mvp-mvvm-angularjs-knockoutjs-backbonejs-reactjs-emberjs-avalonjs.html MVC MVC(Model-View-Controller),M 是指业务模型,V 是指用户界面,C 则是控制器,使用 MVC 的目的是将 M 和 V 的实现代码分离,从而使同一个程序可以使用不同的表现形式. 交互方式(所有通信都是单向的): View 传送指令到 Contro

使用 React.js 的渐进式 Web 应用程序:第 1 部分 - 介绍

来自译者 markzhai:大家也知道最近 Web 越来越火了,如果你还以为 Web 就是 jQuery.Ajax.CSS 什么的,那你就 out 了.给大家几个链接看一看吧: https://shop.polymer-project.org/ https://housing.com/ https://www.flipkart.com/ https://react-hn.appspot.com/ https://mobile.twitter.com/ 部分可能需要自备梯子,另外建议在 Chrom

前端迷思与React.js

前端迷思与React.js 前端技术这几年蓬勃发展, 这是当时某几个项目需要做前端技术选型时, 相关资料整理, 部分评论引用自社区. 开始吧: 目前, Web 开发技术框架选型为两种的占 80% .这种戏剧性的变化持续了近 6 年. 自 2013 年 5 月推出以来,ReactJS 在过去三年中已成为了 Web 开发领域的中坚力量. 任何组件与框架都有它的适用场景, 我们应该冷静分析与权衡, 先来看React.js 1 从功能开发角度说,React的思路很好.2 从页面设计角度说,传统的HTML

Sublime Text 3 搭建 React.js 开发环境

ublime有很强的自定义功能,插件库很庞大,针对新语言插件更新很快,配合使用可以快速搭建适配语言的开发环境. 1. babel 支持ES6, React.js, jsx代码高亮,对 JavaScript, jQuery 也有很好的扩展.关于 babel 的更多介绍可以看这里:为什么说Babel将推动JavaScript的发展 安装 PC:Ctrl+shift+p Mac:Cmd+shift+p 打开面板输入babel安装 配置 打开.js, .jsx 后缀的文件; 打开菜单view, Synt

react.js

---恢复内容开始--- 一.React的定义 React 是由Facebook 创建的一个开源项目.它提供了一种在JavaScript中构建用户界面的全新方式.react针对的是现代风格的JavaScript开发生态系统.React 是一个使用JavaScript 和XML技术(可选)构建可组合用户界面的引擎.下面对React定义的每个部分加以详细的说明: React 是一个引擎:React的网站将它定义为一个库,但是我觉得使用"引擎"这个词更能体现出React的核心优势:用来实现响

React.js终探(七)(完)

我们在前面介绍了组件的各种特性,这一节我们来说说多组件的情况. 在实际开发中,我们的组件难免会遇到有公共部分的情况,如果是个别情况还好,但如果数量比较多的话,那这时候,就需要公用了. 怎么公用呢? React为我们提供了它的方法. mixin:复用代码 可以把部分代码提出来公用.mixin是掺合混合的意思,即可以把一个对象的属性拷贝到另一个对象上. 使用mixin有两步: 定义一个mixin对象,即如 1 var EzLoggerMixin = { 2 log:function(){ 3 //s

10 个打造 React.js App 的最佳 UI 框架

在本文中,我们将分享一些助你打造 React.js App 最佳的 UI 框架.它们具备你所需要的基本 React 组件,以及易用的 API,同时,在外观和体验上也非常棒.Have Fun ! 1. Material-UI 基于谷歌 Material Design 设计规范的 React 组件 此外,它还是 React 的第一个 UI 套件.Material-UI具备你所需要的所有组件(甚至更多),以及可配置性极高的预定义调色板和<MuiThemeProvider>,帮助你为应用程序定制相应的