react入门到进阶(一)
一、何为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)的很多功能
- 列表项
- component instantiated 组件初始化
- getDefaultProps( ) 获取默认属性的生命周期函数
- getInitialState( ) 获取初始化
State的函数 - componentWillMount( ) 组件将要加载
- render( ) 渲染
- componentDidMount( ) 组件加载完毕(第一次render( )完毕后)
- props changed 属性更改
- componentWillReceiveProps( )
- shouldComponentUpdate( )
- componentWillUpdate( ) 组件将要更新
- render( )
- componentDidUpdate( ) 组件更新完毕(第一次render( )完毕,等组件加载完毕)
- setState( )
- 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入门到进阶(一)的更多相关文章
- react 入门与进阶教程
react 入门与进阶教程 前端学习对于我们来说越来越不友好,特别是随着这几年的发展,入门门槛越来越高,连进阶道路都变成了一场马拉松.在学习过程中,我们面临很多选择,vue与react便是一个两难的选 ...
- react入门到进阶(二)
一.react属性与事件 1.State属性 State,翻译过来是状态的意思,所以它就代表着组件的状态.React把用户界面(UI)当做是状态机,想象它有不同的状态然后渲染这些状态,可以轻松让用户界 ...
- react入门到进阶(三)
一.react样式 1.内联样式 在以前写html+css的时候,引入css的时候有一种方法就是内联,而在react中又有些不一样,样式是用变量的形式,如下 const styleComponentH ...
- Weex入门与进阶指南
Weex入门与进阶指南 标签: WeexiOSNative 2016-07-08 18:22 59586人阅读 评论(8) 收藏 举报 本文章已收录于: iOS知识库 分类: iOS(87) 职 ...
- react入门(3)
在第一篇文章里我们介绍了jsx.组件.css写法 点击查看react入门(1) 第二篇文章里我们介绍了事件.this.props.children.props....other.map循环 点击查 ...
- react入门(1)
这篇文章也不能算教程咯,就算是自己学习整理的笔记把. 关于react一些相关的简介.优势之类的,随便百度一下一大堆,我就不多说了,可以去官网(http://reactjs.cn/)看一下. 这片主要讲 ...
- react入门(2)
接着上一次的讲,如果没有看过上一篇文章的小伙伴可以先看一下http://www.cnblogs.com/sakurayeah/p/5807821.html React事件 可以先看一下官网讲解的内容h ...
- react入门(4)
首先还是来回顾一下前三篇讲的内容 react入门(1): jsx,组件,css写法 react入门(2):事件,this.props.children,props,...other react入门(3 ...
- React 入门实例教程(转载)
本人转载自: React 入门实例教程
随机推荐
- ASP.NET Web API 2中的错误处理
前几天在webapi项目中遇到一个问题:Controller构造函数中抛出异常时全局过滤器捕获不到,于是网搜一把写下这篇博客作为总结. HttpResponseException 通常在WebAPI的 ...
- Java IO(IO流)-2
IO流 第一部分 (OutputStreamWriter BufferOutputStream) 转换流 超类为Reader和Writer 是字符流通向字节流的桥梁:可使用指定的字符编码表,将要写入流 ...
- daterangepicker 使用方法以及各种小bug修复
双日历时间段选择插件 — daterangepicker是bootstrap框架后期的一个时间控件,可以设定多个时间段选项,也可以自定义时间段,由用户自己选择起始时间和终止时间,时间段的最大跨度可以在 ...
- 在centos6上实现LAMP的FPM模式
原理 http使用一次编译法编译安装,php独立服务fpm实现. 软件版本 在本次实验中,我们需要用到的软件版本如下: apr-1.6.2 apr-util-1.6.0 httpd-2.4.28 ma ...
- 使用VS2013 + EF6 + .NET4.5 连接Mysql数据库
1.安装插件 在使用Visual Studio 2013添加ADO.NET实体数据模型新建连接时,默认是没有Mysql选项的.此时我们需要安装两个东西: 1.mysql-for-visualstudi ...
- LeetCode 62. Unique Paths(所有不同的路径)
A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below). The ...
- 【SQL注入】mysql中information_schema详解
在MySQL中,把 information_schema 看作是一个数据库,确切说是信息数据库.其中保存着关于MySQL服务器所维护的所有其他数据库的信息.如数据库名,数据库的表,表栏的数据类型与访问 ...
- iOS之 Category 属性 的理解
在 Objective-C 中可以通过 Category 给一个现有的类添加属性,但是却不能添加实例变量 反正读第一遍的时候我是有点晕的,可以添加“属性”,然后又说“添加实例变量”,第一感觉就好像 有 ...
- java基础解析系列(十)---ArrayList和LinkedList源码及使用分析
java基础解析系列(十)---ArrayList和LinkedList源码及使用分析 目录 java基础解析系列(一)---String.StringBuffer.StringBuilder jav ...
- Linux学习(十三)du、df、fdisk磁盘分区
一.du du命令是查看文件或者目录大小的命令. 一般使用du -sh 查看,不用-sh参数意义也不大,应为不用这个参数,它会把目录下的所有文件大小递归的显示出来,就像这样: 如果用-sh参数: [r ...