ReactJs快速入门教程(精华版)


Posted in Javascript onNovember 28, 2016

现在最热门的前端框架有AngularJS、React、Bootstrap等。自从接触了ReactJS,ReactJs的虚拟DOM(Virtual DOM)和组件化的开发深深的吸引了我,下面来跟我一起领略ReactJs的风采吧~~ 文章有点长,耐心读完,你会有很大收获哦~

 ReactJs快速入门教程(精华版)

一、ReactJS简介

React 起源于 Facebook 的内部项目,因为该公司对市场上所有 JavaScript MVC 框架,都不满意,就决定自己写一套,用来架设 Instagram 的网站。做出来以后,发现这套东西很好用,就在2013年5月开源了。由于 React 的设计思想极其独特,属于革命性创新,性能出众,代码逻辑却非常简单。所以,越来越多的人开始关注和使用,认为它可能是将来 Web 开发的主流工具。

ReactJS官网地址:http://facebook.github.io/react/

Github地址:https://github.com/facebook/react

ReactJs快速入门教程(精华版)

 二、对ReactJS的认识及ReactJS的优点

 首先,对于React,有一些认识误区,这里先总结一下:

  • React不是一个完整的MVC框架,最多可以认为是MVC中的V(View),甚至React并不非常认可MVC开发模式;
  • React的服务器端Render能力只能算是一个锦上添花的功能,并不是其核心出发点,事实上React官方站点几乎没有提及其在服务器端的应用;
  • 有人拿React和Web Component相提并论,但两者并不是完全的竞争关系,你完全可以用React去开发一个真正的Web Component;
  • React不是一个新的模板语言,JSX只是一个表象,没有JSX的React也能工作。

1、ReactJS的背景和原理

在Web开发中,我们总需要将变化的数据实时反应到UI上,这时就需要对DOM进行操作。而复杂或频繁的DOM操作通常是性能瓶颈产生的原因(如何进行高性能的复杂DOM操作通常是衡量一个前端开发人员技能的重要指标)。React为此引入了虚拟DOM(Virtual DOM)的机制:在浏览器端用Javascript实现了一套DOM API。基于React进行开发时所有的DOM构造都是通过虚拟DOM进行,每当数据变化时,React都会重新构建整个DOM树,然后React将当前整个DOM树和上一次的DOM树进行对比,得到DOM结构的区别,然后仅仅将需要变化的部分进行实际的浏览器DOM更新。而且React能够批处理虚拟DOM的刷新,在一个事件循环(Event Loop)内的两次数据变化会被合并,例如你连续的先将节点内容从A变成B,然后又从B变成A,React会认为UI不发生任何变化,而如果通过手动控制,这种逻辑通常是极其复杂的。尽管每一次都需要构造完整的虚拟DOM树,但是因为虚拟DOM是内存数据,性能是极高的,而对实际DOM进行操作的仅仅是Diff部分,因而能达到提高性能的目的。这样,在保证性能的同时,开发者将不再需要关注某个数据的变化如何更新到一个或多个具体的DOM元素,而只需要关心在任意一个数据状态下,整个界面是如何Render的。

如果你像在90年代那样写过服务器端Render的纯Web页面那么应该知道,服务器端所要做的就是根据数据Render出HTML送到浏览器端。如果这时因为用户的一个点击需要改变某个状态文字,那么也是通过刷新整个页面来完成的。服务器端并不需要知道是哪一小段HTML发生了变化,而只需要根据数据刷新整个页面。换句话说,任何UI的变化都是通过整体刷新来完成的。而React将这种开发模式以高性能的方式带到了前端,每做一点界面的更新,你都可以认为刷新了整个页面。至于如何进行局部更新以保证性能,则是React框架要完成的事情。

借用Facebook介绍React的视频中聊天应用的例子,当一条新的消息过来时,传统开发的思路如上图,你的开发过程需要知道哪条数据过来了,如何将新的DOM结点添加到当前DOM树上;而基于React的开发思路如下图,你永远只需要关心数据整体,两次数据之间的UI如何变化,则完全交给框架去做。可以看到,使用React大大降低了逻辑复杂性,意味着开发难度降低,可能产生Bug的机会也更少。

2、组件化

虚拟DOM(virtual-dom)不仅带来了简单的UI开发逻辑,同时也带来了组件化开发的思想,所谓组件,即封装起来的具有独立功能的UI部件。React推荐以组件的方式去重新思考UI构成,将UI上每一个功能相对独立的模块定义成组件,然后将小的组件通过组合或者嵌套的方式构成大的组件,最终完成整体UI的构建。例如,Facebook的instagram.com整站都采用了React来开发,整个页面就是一个大的组件,其中包含了嵌套的大量其它组件,大家有兴趣可以看下它背后的代码。

如果说MVC的思想让你做到视图-数据-控制器的分离,那么组件化的思考方式则是带来了UI功能模块之间的分离。我们通过一个典型的Blog评论界面来看MVC和组件化开发思路的区别。

对于MVC开发模式来说,开发者将三者定义成不同的类,实现了表现,数据,控制的分离。开发者更多的是从技术的角度来对UI进行拆分,实现松耦合。

对于React而言,则完全是一个新的思路,开发者从功能的角度出发,将UI分成不同的组件,每个组件都独立封装。

在React中,你按照界面模块自然划分的方式来组织和编写你的代码,对于评论界面而言,整个UI是一个通过小组件构成的大组件,每个组件只关心自己部分的逻辑,彼此独立。

ReactJs快速入门教程(精华版)

React认为一个组件应该具有如下特征:

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

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

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

三、下载ReactJS,编写Hello,world

 

ReactJs下载非常简单,为了方便大家下载,这里再一次给出下载地址http://facebook.github.io/react/downloads.html,下载完成后,我么看到的是一个压缩包。解压后,我们新建一个html文件,引用react.js和JSXTransformer.js这两个js文件。html模板如下(js路径改成自己的):

<!DOCTYPE html>
<html>
 <head>
 <script src="build/react.js"></script>
 <script src="build/JSXTransformer.js"></script>
 </head>
 <body>
 <div id="container"></div>
 <script type="text/jsx">
  // ** Our code goes here! **
 </script>
 </body>
</html>

这里大家可能会奇怪,为什么script的type是text/jsx,这是因为 React 独有的 JSX 语法,跟 JavaScript 不兼容。凡是使用 JSX 的地方,都要加上 type="text/jsx" 。 其次,React 提供两个库: react.js 和 JSXTransformer.js ,它们必须首先加载。其中,JSXTransformer.js 的作用是将 JSX 语法转为 JavaScript 语法。这一步很消耗时间,实际上线的时候,应该将它放到服务器完成。

到这里我们就可以开始编写代码了,首先我们先来认识一下ReactJs里面的React.render方法:

React.render 是 React 的最基本方法,用于将模板转为 HTML 语言,并插入指定的 DOM 节点。

下面我们在script标签里面编写代码,来输出Hello,world,代码如下:

React.render(
  <h1>Hello, world!</h1>,
  document.getElementById('container')
  );

这里需要注意的是,react并不依赖jQuery,当然我们可以使用jQuery,但是render里面第二个参数必须使用JavaScript原生的getElementByID方法,不能使用jQuery来选取DOM节点。

 然后,在浏览器打开这个页面,就可以看到浏览器显示一个大大的Hello,world,因为我们用了<h1>标签。

到这里,恭喜,你已经步入了ReactJS的大门~~下面,让我们来进一步学习ReactJs吧~~

 四、Jsx语法

 

HTML 语言直接写在 JavaScript 语言之中,不加任何引号,这就是 JSX 的语法,它允许 HTML 与 JavaScript 的混写,了解过AngularJs的看到下面的代码一定会感觉很熟悉的,我们来看代码:

var names = ['Jack', 'Tom', 'Alice'];
  React.render(
  <div>
  {
   names.map(function (name) {
   return <div>Hello, {name}!</div>
   })
  }
  </div>,
  document.getElementById('container')
  );

这里我们声明了一个names数组,然后遍历在前面加上Hello,输出到DOM中,输出结果如下:

JSX 允许直接在模板插入 JavaScript 变量。如果这个变量是一个数组,则会展开这个数组的所有成员,代码如下:

var arr = [
  <h1>Hello world!</h1>,
  <h2>React is perfect!</h2>,
  ];
  React.render(
  <div>*{arr}*</div>,
  document.getElementById('container')
  );

显示结果如下:

ReactJs快速入门教程(精华版)

这里的星号只是做标识用的,大家不要被她迷惑了~~

 你看到这里,说明你对React还是蛮感兴趣的,恭喜你,坚持下来了,那么下面,我们开始学习React里面的"真功夫"了~~ Are you ready?

 五、ReactJS组件

1、组件属性

前面说了,ReactJS是基于组件化的开发,下面我们开始来学习ReactJS里面的组件,React 允许将代码封装成组件(component),然后像插入普通 HTML 标签一样,在网页中插入这个组件。React.createClass 方法就用于生成一个组件类。

下面,我们来编写第一个组件Greet,有一个name属性,然后输出hello + name的值,代码如下:

var Greet = React.createClass({
  render: function() {
   return <h1>Hello {this.props.name}</h1>;
  }
  });
  React.render(
  <Greet name="Jack" />,
  document.getElementById('container')
  );

看到这段代码,接触过AngularJS的朋友们是不是有一种熟悉的感觉,不过这里有几点需要注意:

1、获取属性的值用的是this.props.属性名

2、创建的组件名称首字母必须大写。

3、为元素添加css的class时,要用className.

4、组件的style属性的设置方式也值得注意,要写成style={{width: this.state.witdh}}

2、组件状态

组件免不了要与用户互动,React 的一大创新,就是将组件看成是一个状态机,一开始有一个初始状态,然后用户互动,导致状态变化,从而触发重新渲染 UI 。下面我们来编写一个小例子,一个文本框和一个button,通过点击button可以改变文本框的编辑状态,禁止编辑和允许编辑。通过这个例子来理解ReactJS的状态机制。先看代码:

var InputState = React.createClass({
  getInitialState: function() {
   return {enable: false};
  },
  handleClick: function(event) {
   this.setState({enable: !this.state.enable});
  },
  render: function() {
   return (
   <p>
    <input type="text" disabled={this.state.enable} />
    <button onClick={this.handleClick}>Change State</button>
   </p>
   );
  }
  });
  React.render(
  <InputState />,
  document.getElementById('container')
  );

这里,我们又使用到了一个方法getInitialState,这个函数在组件初始化的时候执行,必需返回NULL或者一个对象。这里我们可以通过this.state.属性名来访问属性值,这里我们将enable这个值跟input的disabled绑定,当要修改这个属性值时,要使用setState方法。我们声明handleClick方法,来绑定到button上面,实现改变state.enable的值.效果如下:

ReactJs快速入门教程(精华版)

原理分析:

 

当用户点击组件,导致状态变化,this.setState 方法就修改状态值,每次修改以后,自动调用 this.render 方法,再次渲染组件。

这里值得注意的几点如下:

1、getInitialState函数必须有返回值,可以是NULL或者一个对象。

2、访问state的方法是this.state.属性名。

3、变量用{}包裹,不需要再加双引号。

3、组件的生命周期  

组件的生命周期分成三个状态:

  • Mounting:已插入真实 DOM
  • Updating:正在被重新渲染
  • Unmounting:已移出真实 DOM

React 为每个状态都提供了两种处理函数,will 函数在进入状态之前调用,did 函数在进入状态之后调用,三种状态共计五种处理函数。

  • componentWillMount()
  • componentDidMount()
  • componentWillUpdate(object nextProps, object nextState)
  • componentDidUpdate(object prevProps, object prevState)
  • componentWillUnmount()

此外,React 还提供两种特殊状态的处理函数。

  • componentWillReceiveProps(object nextProps):已加载组件收到新的参数时调用
  • shouldComponentUpdate(object nextProps, object nextState):组件判断是否重新渲染时调用 

下面来看一个例子:

var Hello = React.createClass({
  getInitialState: function () {
   return {
   opacity: 1.0
   };
  },
  componentDidMount: function () {
   this.timer = setInterval(function () {
   var opacity = this.state.opacity;
   opacity -= .05;
   if (opacity < 0.1) {
    opacity = 1.0;
   }
   this.setState({
    opacity: opacity
   });
   }.bind(this), 100);
  },
  render: function () {
   return (
   <div style={{opacity: this.state.opacity}}>
    Hello {this.props.name}
   </div>
   );
  }
  });
  React.render(
  <Hello name="world"/>,
  document.body
  );

上面代码在hello组件加载以后,通过 componentDidMount 方法设置一个定时器,每隔100毫秒,就重新设置组件的透明度,从而引发重新渲染。

4、组件的嵌套

React是基于组件化的开发,那么组件化开发最大的优点是什么?毫无疑问,当然是复用,下面我们来看看React中到底是如何实现组件的复用的,这里我们还写一个例子来说吧,代码如下:

var Search = React.createClass({
  render: function() {
   return (
   <div>
    {this.props.searchType}:<input type="text" />
    <button>Search</button>
   </div>
   );
  }
  });
  var Page = React.createClass({
  render: function() {
   return (
   <div>
    <h1>Welcome!</h1>
    <Search searchType="Title" />
    <Search searchType="Content" />
   </div>
   );
  }
  });
  React.render(
  <Page />,
  document.getElementById('container')
  );

这里我们创建了一个Search组件,然后又创建了一个Page组件,然后我们在Page组件中调用Search组件,并且调用了两次,这里我们通过属性searchType传入值,最终显示结果如图:

ReactJs快速入门教程(精华版)

 六、ReactJs小结

关于ReactJS今天就先学习到这里了,下面来总结一下,主要有以下几点:

1、ReactJs是基于组件化的开发,所以最终你的页面应该是由若干个小组件组成的大组件。

2、可以通过属性,将值传递到组件内部,同理也可以通过属性将内部的结果传递到父级组件(留给大家研究);要对某些值的变化做DOM操作的,要把这些值放到state中。

3、为组件添加外部css样式时,类名应该写成className而不是class;添加内部样式时,应该是style={{opacity: this.state.opacity}}而不是style="opacity:{this.state.opacity};"

4、组件名称首字母必须大写。

5、变量名用{}包裹,且不能加双引号。

以上所述是小编给大家介绍的ReactJs快速入门教程(精华版),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jquery序列化form表单使用ajax提交后处理返回的json数据
Mar 03 Javascript
iframe子页面与父页面在同域或不同域下的js通信
May 07 Javascript
JS动态增加删除UL节点LI及相关内容示例
May 21 Javascript
使用HTML+CSS+JS制作简单的网页菜单界面
Jul 27 Javascript
jquery点击缩略图切换视频播放特效代码分享
Sep 15 Javascript
jQuery自制提示框tooltip改进版
Aug 01 Javascript
利用Node.JS实现邮件发送功能
Oct 21 Javascript
Bootstrap表单控件学习使用
Mar 07 Javascript
layui清空,重置表单数据的实例
Sep 12 Javascript
layer提示框添加多个按钮选择的实例
Sep 12 Javascript
jQuery实现移动端下拉展现新的内容回弹动画
Jun 24 jQuery
vue2实现provide inject传递响应式
May 21 Vue.js
js窗口震动小程序分享
Nov 28 #Javascript
JS获取年月日时分秒的方法分析
Nov 28 #Javascript
js中string和number类型互转换技巧(分享)
Nov 28 #Javascript
浅析使用BootStrap TreeView插件实现灵活配置快递模板
Nov 28 #Javascript
基于JavaScript实现右键菜单和拖拽功能
Nov 28 #Javascript
JavaScript实现图片懒加载(Lazyload)
Nov 28 #Javascript
最常见的左侧分类菜单栏jQuery实现代码
Nov 28 #Javascript
You might like
PHP命名空间(namespace)的动态访问及使用技巧
2014/08/18 PHP
Yii框架form表单用法实例
2014/12/04 PHP
Zend Framework教程之视图组件Zend_View用法详解
2016/03/05 PHP
php生成图片验证码的方法
2016/04/15 PHP
thinkPHP框架可添加js事件的分页类customPage.class.php完整实例
2017/03/16 PHP
Windows下wamp php单元测试工具PHPUnit安装及生成日志文件配置方法
2018/05/28 PHP
php微信公众号开发之校园图书馆
2018/10/20 PHP
JQuery 初体验(建议学习jquery)
2009/04/25 Javascript
JQuery 常用操作代码
2010/03/14 Javascript
javascript与webservice的通信实现代码
2010/12/25 Javascript
jQuery LigerUI 使用教程表格篇(1)
2012/01/18 Javascript
前台js改变Session的值(用ajax实现)
2012/12/28 Javascript
关于jQuery参考实例2.0 用jQuery选择元素
2013/04/07 Javascript
浏览器图片选择预览、旋转、批量上传的JS代码实现
2013/12/04 Javascript
JavaScript中的条件判断语句使用详解
2015/06/03 Javascript
js仿百度切换皮肤功能(html+css)
2016/07/10 Javascript
JavaScript中的对象继承关系
2016/08/01 Javascript
微信小程序中使元素占满整个屏幕高度实现方法
2016/12/14 Javascript
vue的常用组件操作方法应用分析
2018/04/13 Javascript
Vue作用域插槽slot-scope实例代码
2018/09/05 Javascript
vue elementui el-form rules动态验证的实例代码详解
2019/05/23 Javascript
webpack的 rquire.context用法实现工程自动化的方法
2020/02/07 Javascript
python实现DEM数据的阴影生成的方法
2019/07/23 Python
python下载库的步骤方法
2019/10/12 Python
Python发送邮件的实例代码讲解
2019/10/16 Python
Python语言异常处理测试过程解析
2020/01/08 Python
使用CSS3的box-sizing属性解决div宽高被内边距撑开的问题
2016/06/28 HTML / CSS
HTML利用九宫格原理进行网页布局
2020/03/13 HTML / CSS
韩国著名的在线综合购物网站:Akmall
2016/08/07 全球购物
编写类String 的构造函数、析构函数和赋值函数
2012/09/09 面试题
车祸赔偿收入证明
2014/01/09 职场文书
写演讲稿所需要注意的4个条件
2014/01/09 职场文书
超搞笑婚前保证书
2015/05/08 职场文书
培训简讯范文
2015/07/20 职场文书
2016年教代会开幕词
2016/03/04 职场文书
CSS控制继承中的height能变为可继承吗
2022/06/10 HTML / CSS