一、何为react

Facebook在F8会议上首次提出这个概念,一套全新的框架就此诞生。

  • React 不是一个完整的 MVC、MVVM 框架,其只负责 View 层
  • React 跟 Web Components 不冲突
  • React 的特点就是“轻”,数据单向绑定,独立、小巧、快速、创新
  • 组件化的开发思路,小组件构成大组件,高度可重用

而react则广泛应用于

  • 复杂场景下的高性能
  • 重用组件库,组件组合

二、react组件基础

1、react虚拟dom概念

当一个数据改变时,而你又需要将它实时反应到UI上时,你就需要对DOM进行操作,但是复杂或频繁的DOM操作通常是性能瓶颈产生的原因,于是我们在app源码DOM之间加入了虚拟DOM(Virtual DOM)。

所以在React中,render执行的结果得到的并不是真正的DOM节点,结果仅仅是轻量级的JavaScript对象,我们称之为virtual DOM

虚拟DOM是React的一大亮点,具有batching(批处理)和高效的Diff算法这让我们可以无需担心性能问题而”毫无顾忌”的随时“刷新”整个页面,由虚拟 DOM来确保只对界面上真正变化的部分进行实际的DOM操作。如果没有 Virtual DOM,简单来说就是直接重置 innerHTML。这样操作,在一个大型列表所有数据都变了的情况下,还算是合理,但是,当只有一行数据发生变化时,它也需要重置整个 innerHTML,这时候显然就造成了大量浪费。

2、react组件

先来个小例子看看什么是react组件,创建一个js文件

import React from 'react';
import ReactDom from 'react-dom'; export default class ComponentHeader extends React.Component{
render(){
return(
<header>
<h1>yondu is a good father</h1>
</header>
)
}
}

这个文件就创建了一个名为ComponentHeader 的组件,值得注意的是export default是可以让这个组件外用。

然后我们在一个项目的入口文件里引用这个组件

var React = require('react');
var ReactDOM = require('react-dom');
import ComponentHeader from './components/header';//组件文件的相对位置 class Index extends React.Component {
render(){
return(
<ComponentHeader/>
);
}
}//创建可以用ComponentHeader组件的组件Index
ReactDOM.render(<Index/>,document.getElementById('example'));//把你创建的组件在id为example的dom中使用

当然在render中,你也可以用一个参数的形式,它的作用是可以用于判断,例如

var component = <ComponentHeader/>//在render中,就可以直接用component代替<ComponentHeader/>
//所以可以有以下形式
if(ture){
component = <ComponentHeader/>
}
else{
component = <ComponentFooter/>
}

以上例子就是创建一个组件然后使用的过程,需要注意的地方是

  • 组件的return函数里返回的html节点只能是一个,如有多个,可以在外面包一个<div></div>
  • 如果想让组件外用,加上export default

3、JSX内置表达式

三元表达式是JSX里面经常使用的一种语法,我们先来看一看

render(){
var text="不为空";
return(
<p>{text == "" ? "内容为空" : "内容为"+text}/p>
)
}

首先表达式要用{}包裹,然后三元表达式主要是看三元运算符,语法是 条件 ? 结果1 : 结果2;. 这里你把条件写在问号(?)的前面后面跟着用冒号(:)分隔的结果1和结果2。满足条件时结果1否则结果2。

(b == 5) ? a="true" : a="false";

在JSX中用动态绑定时,参数需要用{}包裹,而且外面不需要用引号,例如

render(){
var bool=true;
var name="点一下";
return(
<input type="button" value={name} disabled={bool}>
)
}

JSX中的注释是这样{/*注释*/}的形式

4、生命周期

可以利用生命周期函数做到钩子函数(Hook)的很多功能

  1. 列表项
  2. component instantiated 组件初始化
    • getDefaultProps( ) 获取默认属性的生命周期函数
    • getInitialState( ) 获取初始化State的函数
    • componentWillMount( ) 组件将要加载
    • render( ) 渲染
    • componentDidMount( ) 组件加载完毕(第一次render( )完毕后)
  3. props changed 属性更改
    • componentWillReceiveProps( )
    • shouldComponentUpdate( )
    • componentWillUpdate( ) 组件将要更新
    • render( )
    • componentDidUpdate( ) 组件更新完毕(第一次render( )完毕,等组件加载完毕)
  4. setState( )
  5. component deleted
    • componentWillUnmount( ) 组件卸载函数 (第一次render( )完毕,等组件更新完毕)

我们可以看看

var React = require('react');
var ReactDOM = require('react-dom');
import ComponentHeader from './components/header'; class Index extends React.Component {
componentWillMount(){
//直接写逻辑
console.log("Index组件将要加载的时间");
}
render(){
return(
<ComponentHeader/>
);
}
componentDidMount(){
//直接写逻辑
console.log("Index组件加载完毕的时间");
}
}
ReactDOM.render(<Index/>,document.getElementById('example'));

生命周期函数的运用如上就可见一斑了。

react入门到进阶(一)的更多相关文章

  1. react 入门与进阶教程

    react 入门与进阶教程 前端学习对于我们来说越来越不友好,特别是随着这几年的发展,入门门槛越来越高,连进阶道路都变成了一场马拉松.在学习过程中,我们面临很多选择,vue与react便是一个两难的选 ...

  2. react入门到进阶(二)

    一.react属性与事件 1.State属性 State,翻译过来是状态的意思,所以它就代表着组件的状态.React把用户界面(UI)当做是状态机,想象它有不同的状态然后渲染这些状态,可以轻松让用户界 ...

  3. react入门到进阶(三)

    一.react样式 1.内联样式 在以前写html+css的时候,引入css的时候有一种方法就是内联,而在react中又有些不一样,样式是用变量的形式,如下 const styleComponentH ...

  4. Weex入门与进阶指南

    Weex入门与进阶指南 标签: WeexiOSNative 2016-07-08 18:22 59586人阅读 评论(8) 收藏 举报 本文章已收录于:  iOS知识库  分类: iOS(87)  职 ...

  5. react入门(3)

    在第一篇文章里我们介绍了jsx.组件.css写法  点击查看react入门(1) 第二篇文章里我们介绍了事件.this.props.children.props....other.map循环  点击查 ...

  6. react入门(1)

    这篇文章也不能算教程咯,就算是自己学习整理的笔记把. 关于react一些相关的简介.优势之类的,随便百度一下一大堆,我就不多说了,可以去官网(http://reactjs.cn/)看一下. 这片主要讲 ...

  7. react入门(2)

    接着上一次的讲,如果没有看过上一篇文章的小伙伴可以先看一下http://www.cnblogs.com/sakurayeah/p/5807821.html React事件 可以先看一下官网讲解的内容h ...

  8. react入门(4)

    首先还是来回顾一下前三篇讲的内容 react入门(1): jsx,组件,css写法 react入门(2):事件,this.props.children,props,...other react入门(3 ...

  9. React 入门实例教程(转载)

    本人转载自: React 入门实例教程

随机推荐

  1. mongdb单节点安装方法

    mongo单节点环境安装(linux) 安装包 下载地址: (https://www.mongodb.com/download-center) 用户权限/目录 创建 dbuser用户 groupadd ...

  2. OMP算法代码学习

    正交匹配追踪(OMP)算法的MATLAB函数代码并给出单次测试例程代码 测量数M与重构成功概率关系曲线绘制例程代码 信号稀疏度K与重构成功概率关系曲线绘制例程代码   参考来源:http://blog ...

  3. 【JAVA零基础入门系列】Day9 Java中的那个大数值

    什么是大数值?用脚趾头想也知道,当然是"大"的数值(233).Java中有两个用于表示大数值的类,BigInteger和BigDecimal,那到底能表示多大的数值呢?理论上,可以 ...

  4. 【前端】Require.js使用方法总结

    一.为什么要使用require.js 首先一个页面如果在加载多个js文件的时候,浏览器会停止网页渲染,加载文件越多,网页失去响应的时间就会越长:其次,由于js文件之间存在依赖关系,因此必须严格保证加载 ...

  5. 树莓派.使用Node.js来制作一个作业检查仪

    先上图 前段时间, 花了点时间给女儿做了个数学习题的小程序 首页 做题界面(题目每次都随机生成, 加减乘除都有) 做题记录 现在问题来了, 怎么才能随时知道作业有没有完成呢? 每次打开做题记录页面刷新 ...

  6. jsp页面接收json字符串

    jsp页面接收 后台添加

  7. Windows7搭建Wamp环境

    wamp:Windows + Apache + MySQL + PHP 首先,在D盘根目录下新建目录wamp,wamp下建目录www和bin,www目录作为网站文件入口目录,bin下建目录Apache ...

  8. LeetCode 153. Find Minimum in Rotated Sorted Array (在旋转有序数组中找到最小值)

    Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand. (i.e. ...

  9. LeetCode 74. Search a 2D Matrix(搜索二维矩阵)

    Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ...

  10. DataTable数据修改,换列

    增加列             DataTable table= new DataTable();             table.Columns.Add("ID", type ...