React.JS一点通

| 导语 当 React 刚开始红的时候,一直觉得 JSX 的设计思想极其独特,属于革命性的创新,它性能出众,代码逻辑却非常简单,所以,受到很多开发者的关注和使用,认为它可能是将来 Web 开发的主流工具。

React 最早起源于 Facebook 的一个内部项目,因为公司对现有的 JavaScript MVC 框架都不满意,就决定自己开发一套,用来架设 Instagram 的网站。开发完成后,发现这套东西很好用,就在2013年5月开源了。

那么 React 优势在哪里呢?

首先:

虚拟 DOM,在 DOM 树的状态需要发生变化时,虚拟 DOM 机制会将同一Event loop前后的 DOM树进行对比,如果两个 DOM 树存在不一样的地方,那么 React 仅仅会针对这些不一样的区域来进行响应的 DOM 修改,从而实现最高效的 DOM 操作和渲染。

比如,我们修改了 DOM 树上一些节点或 UI 组件对应绑定的 state,React 会即刻将其标记为“脏状态”,在一个 Event loop 结束时,React 会计算得出 DOM 树上需要修改的地方及其最终的状态,并仅仅针对这些地方进行一次性的重新渲染。

于是好处显而易见,并非每修改一次组件的 state,就会重新渲染一次,而是在 Event loop 结束后做一次计算,减少冗余的 DOM 操作。另外 React 只针对需要修改的地方来做新的渲染,而非重新渲染整个 DOM 树,自然效率很高。

其次:

组件可嵌套,而且,可以模版化 —— 其实在 React 里提及的“组件”,常规是一些可封装起来、复用的 UI 模块,可以理解为“带有细粒度UI功能的部分DOM区域”。然后我们可以把这些组件层层嵌套起来使用,当然这样组件间会存在依赖关系。

至于模块化,类似于 ejs 那样可以作为独立的模块被引用到页面上来复用,它可以直接把 UI 组件当作脚本模块那样来使用,完全可以配合 CommonJS、AMD、CMD 等规范来 require 需要的组件模块,并处理好它们的依赖关系。

基于上述的两点,React 很自然的就获得一部分开发者的青睐。不过在这之前得先理清两件事情:

1. React 是一个纯 View 层,不擅长于和动态数据打交道,因此它不同于,也替代不了常规的框架;

2. React 很擅长于处理组件化的页面,在页面上搭组件的形式有点像搭积木一样,因此用上React的项目需求常规为界面组件化。

简单点说,React组件应该具有如下特征:

(1)可组合(Composeable):一个组件易于和其它组件一起使用,或者嵌套在另一个组件内部。如果一个组件内部创建了另一个组件,那么说父组件拥有它创建的子组件,通过这个特性,一个复杂的UI可以拆分成多个简单的 UI 组件;

(2)可重用(Reusable):每个组件都是具有独立功能的,它可以被使用在多个UI场景;

(3)可维护(Maintainable):每个小的组件仅仅包含自身的逻辑,更容易被理解和维护;

组件化一直是网页开发的利器,许多开发者最希望能够最大程度的重复使用过去的开发的组件,避免重复造轮子。在 React 中组件就是一切,前端开发可能需要花点时间转变思维,尤其过去我们往往习惯将 HTML 、CSS 和 JavaScript 分离,现在却要把它们都封装在一起。

以下是一般  React Component 书写的主要两种方式:

1.使用 ES6 的 Class

//  注意组件首字母需要大写

class MyComponent extends React.Component {

// render 是 Class based 元件唯一必須的方法(method)

render() {

return (

<div>Hello, World!</div>

);

}

}

// 將 <MyComponent /> 组件插入 id 為 app 的 DOM 元素中

ReactDOM.render(<MyComponent/>, document.getElementById('app'));

2.使用 Functional Component 写法

// 使用 arrow function 来设计 Functional Component 让 UI 设计更便捷,避免互相干扰(side effect)

const MyComponent = () => (

<div>Hello, World!</div>

);

// 將 <MyComponent /> 组件插入 id 為 app 的 DOM 元素中

ReactDOM.render(<MyComponent/>, document.getElementById('app'));

前面说到 React 有独有的 JSX 语法,那么到底什么是 JSX 呢?

JSX在ECMAScript的基础上提供了类似于XML的扩展。 JSX和HTML有点像,但也有不一样的地方。例如,HTML中的class属性在JSX中 为className。其他不一样的地方,你可以参考FB的HTML Tags vs. React Components 这篇文章。

但是由于浏览器原生并不支持JSX,因此我们需要将其编译为JS,有很多方法能够 完成这个任务,后面我们会提到这些方法。此外,Babel也能够讲JSX编译为JS。

一般而言 JSX 通常有两种使用方式:

1.使用 browserify 或 webpack 等 CommonJS bundler 并整合 babel 预处理

2.在浏览器端做解析

请大家注意JSX的语法书写方式:

<!DOCTYPE html>

<html>

  <head>

    <meta charset="UTF-8" />

    <title>Hello React!</title>

   <!-- 請先载入 index.html 中引入 react.js, react-dom.js 和 babel-core 的 browser.min.js -->

    <script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.0.1/react.min.js"></script>

    <script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.0.1/react-dom.min.js"></script>

    <script src="https://cdnjs.cloudflare.com/ajax/libs/babel-core/5.8.23/browser.min.js"></script>

  </head>

  <body>

    <div id="example"></div>

    <script type="text/babel">

      // 代码写在这里!

      ReactDOM.render(

        <h1>Hello, world!</h1>,

        document.getElementById('example')

      );

    </script>

  </body>

</html>

一般载入 JSX 方式有:

內嵌

<script type="text/babel">

  ReactDOM.render(

    <h1>Hello, world!</h1>,

    document.getElementById('example')

  );

</script>

从外部引入

  <script type="text/jsx" src="main.jsx"></script>   

总结:

以上都是我对 React 简单的了解,包括 React 的优势、组件化的特征、React Component 的方法、以及 React 中为何要使用 JSX,以及 JSX 基本概念和用法。在  React 里,所有的事物都是以 Component 为基础,通常会将同一个 Component  相关的资源放在一起,而在撰写  React Component 时我们常会使用 JSX 的方式来提升书写效率。 JSX 是一种语法类似 XML 的 ECMAScript  语法扩充,可以发挥 JavaScript 的强大能力,放弃蹩脚的模板语言。当然 JSX 并非强制使用,你也可以选择不用,因为最终 JSX 的内容都会转化成 JavaScript。

---------------------------------------------------------------

原文作者,腾讯工程师Nick。

原文发布于微信公众号 - 腾讯NEXT学位(NextDegree)

原文发表时间:2018-08-03

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏hrscy

iOS百度地图开发中遇到的问题

由于项目需要地图功能,公司决定使用百度地图,但是百度地图也有很多问题,现在总结一下在百度地图中遇到的坑,希望给各位看官一点参考,避免走一些弯路.我使用的百度地图...

8220
来自专栏web前端教室

聊一下JavaScript定时器

image.png 话说JS的定时器,常用的其实就是setTimeout和setInterval这二个。它们俩一个是运行一次就拉倒,另一个是你不叫我停我就一...

26390
来自专栏快乐八哥

Web开发之CSS

  Web开发,除了后台开发和数据开发,很大一块是前端开发。前端开发中使用最大的技术是:HTML(现在也有项目开始使用HTML5了,比如沪江英语的听力曲线使用h...

219100
来自专栏王二麻子IT技术交流园地

HTML出现错位的问题

引起网页HTML显示错位的几个常见问题:          1、在HTML代码中缺失元素的开始或结束标签          2、CSS设置中对边界、填充或边框的...

24150
来自专栏青玉伏案

窥探Swift编程之在Playground上尽情的玩耍

  自从苹果公司发布Swift的时候,Xcode上又多了一样新的东西---"Playground"。Playground就像操场一样,可以供我们在代码的世界里尽...

22080
来自专栏九彩拼盘的叨叨叨

九彩拼盘的前端技能

11720
来自专栏知晓程序

一个天气小程序和他们跳过的 47 个坑,你该如何避免?

18820
来自专栏小李刀刀的专栏

[译]CSS边框实现“无图化”设计

原文:http://www.yuiblog.com/blog/2011/03/08/css-border-tricks-with-collapsed-boxes...

37680
来自专栏liulun

学习WPF——使用Font-Awesome图标字体

图标字体介绍 在介绍图标字体之前,不得不介绍图标格式ICON ICON是一种图标格式,我们操作系统中各种应用程序都包含一个图标 比如QQ程序的图标是一个可...

33650
来自专栏Coco的专栏

神秘的 shadow-dom 浅析

30840

扫码关注云+社区

领取腾讯云代金券