一、React 是什么?
React 是一个由 facebook 开源的 前端框架,核心专注于视图,目的是实现组件化开发;
- 组件化的概念
 
我们可以很直观的将有一个复杂的页面分割成若干个独立的组件,每个组件包含自己的 html 结构、样式和js逻辑,然后再将这些组件组合,即可完成一个复杂的页面。这样既减少了逻辑的复杂度,又实现了代码的重用;
- 组件化的优势:
 
- 可组合:一个组件可以和其他组件一起使用或者可以直接嵌套在另一个组件内部
 - 可重用:每个组件都具有独立的功能,他可以被使用在多个场景中
 - 可维护:每个小的组件仅仅包含自身的逻辑,更容易被理解和维护
 
二、 配置 React 的开发环境
- 安装 react 的脚手架 create-react-app :
 
npm install create-react-app -g
- 使用 react 脚手架初始化一个项目:create-react-app 项目名,例如 :
 
create-react-app first-app
- 等待依赖安装完成,然后执行:
 
cd first-appnpm start
三、React 的组成部分
react由两部分组成:
- react.js 是 React 的核心库
 - react-dom.js 是提供与 DOM 相关的功能,会在 window 下增加 ReactDOM 属性;其中常用的是 render 方法,render 可以将 react 元素或者组件插入到页面中;
 
四、jsx 语法
4.1 什么是 jsx 语法
jsx 语法是一种 js 和 HTML 混写的语法,将组件的结构,数据甚至样式都聚合在一起定义组件,最终经过编译形成普通的 javascript;
在 jsx 中,长得像 HTML 元素的就是 react 元素,React 使用 jsx 语法开发,学习 React 需要掌握 jsx 语法;
jsx 可以写在 js 文件中,也可以新建 .jsx 文件;但是在 js 文件中需要导入 React
import React from 'react'// 导入 React 之后才能开始写 jsx 语法
4.2 jsx 示例
import React from 'react'import ReactDOM from 'react-dom'let data = {name: '马宾',age: 18};let h = <h1 id="xyz">姓名:{ data.name }, 年龄:{ data.age }</h1>; // 这个 h 就是一个 react 元素,也可以成jsx元素,这个元素是虚拟DOM(js对象)// 把 react 元素渲染到页面中ReactDOM.render(h, document.querySelector('#root'), () => {console.log('100');console.log(document.getElementById('xyz'))});
4.3 使用 jsx 的注意事项
- JSX 元素需要放到 ReactDOM.render() 函数中,且最外层只能有一个根节点;
 - 需要注意 jsx 是js,写 jsx 需注意遵守 js 的语法;
 - jsx 元素可以通过 { } 来使用表达式,注意只能是表达式,不允许写语句
 - jsx 元素同样可以使用行内属性,但是 原来 html 行内的 class 属性,在 jsx 中有特殊意义,需要改成 className ;原有的 label 的 for 属性,需要改成 htmlFor ; style属性要写成对象的形式
 - jsx 元素(react元素)并不是真正的 DOM,而是虚拟 DOM ,最终经过 babel 编译成普通js的对象;
 
示例:
let d1 = <div className="x1">这是一个div { false ? 1 : 0 }</div>let d2 = (<div className={ false ? 'x1' : 'y1' }>这是一个div<p>这里面减值可以写一个html</p></div>); // 如果换行用小括号包裹起来let d3 = <div style={{color: 'red', background: '#000'}}>11111<label htmlFor="name"><input type="text" defaultValue={data.name} id="name" /></label></div>;ReactDOM.render(d3, document.getElementById('root'));
4.4 ReactDOM.render() 渲染
- 在执行 render 时,先将jsx虚拟的 DOM 元素转换成真实的 DOM 元素
 - 并且把当前真实的 DOM 插入到真实的DOM元素中
 - 把DOM 渲染到真实的 DOM 之后,才会执行后面的回调函数,可以在这个函数中操作 DOM;
 
五、在 React 中使用样式
在 react 中使用样式,直接在 js 中通过 import 导入 css 样式;最终打包的时候,webpack 会帮我们把样式处理好;
5.1 示例
import React from 'react'import ReactDOM from 'react-dom'import './css/3-css.css' // 在 react 中使用样式,直接在 js 中通过 import 导入 css 样式let p1 = <p className="p1">这是一个p标签</p>; // 注意不能使用 class 指定元素类名,而应该使用 className 属性ReactDOM.render(p1, document.querySelector('#root'));
六、列表渲染和条件渲染
6.1 列表渲染
React 和 Vue 类似都是数据驱动的,都可以根据给定的数据生成一组 DOM 元素,或者根据数据的特定情况生成或者不生成 DOM 元素;在 Vue 中使用 v-for 指令,但是 React 没有指令系统,需要使用 数组的 map 方法,在 map方法的回调函数中返回要生成的 jsx 元素;
- 示例:
 
import React from 'react'import ReactDOM from 'react-dom'let ary = [{name: '马宾',age: 18,title: '宇宙集团军总司令'},{name: '小飞',age: 17,title: '银河小魔仙'}];// 在 Vue 中使用 v-for,但是 React 中没有指令// 在 React 中使用列表渲染,需要使用 数组的 map 方法,在 map 方法的回调函数中返回要生成多个的元素;// 使用传统的匿名函数:let lis = ary.map(function (item, index) {return <li key={index}>姓名:{item.name};年龄:{item.age};职务:{item.title}</li>}); // map 方法将原数组映射成一个新数组,console.log(lis); // 虚拟 DOM 数组let ul = (<ul>{lis} {/*使用列表渲染出来的数据,在 html 里面使用需要使用 { lis }*/}</ul>);// 使用 箭头函数let ul2 = (<ol>{ary.map((item, index) => <li key={index}>name: {item.name}; age: {item.age}; title: {item.title}</li>)}</ol>);ReactDOM.render(ul2, document.querySelector('#root'));
6.2 条件渲染
React 同样没有 v-if,但是需要条件渲染,就需要使用 if-else 等判断语句
- 示例:
 
let flag = Math.round(Math.random() * 10)let el;if (flag > 5) {el = <h1>大于5</h1>} else {el = <h1> 小于等于 5</h1>}
七、React.createElement
React.createElement() 方法是用来创建虚拟 DOM 的方法,而 jsx 语法中,jsx 元素就是 createElement 方法的语法糖;
7.1 React.createElement(type, props, …children) 参数
- type: 标签类型
 - props: 行内属性,对象数据类型
 - children: 从第三个参数开始都是 type 的子元素
 
7.2 示例:
import React from 'react';import ReactDOM from 'react-dom';let ele = (<h1 x="1" y="2">hello<span s="1">1</span><span>2</span></h1>);let eleByCreateElement = React.createElement('h1',{x: 1, y: 2},'hello',React.createElement('span', {s: 1}, 1),React.createElement('span', null, 2));// React.createElement(type, props, ...children)// type: 标签类型// props: 行内属性,对象数据类型// children: 从第三个参数开始都是 type 的子元素ReactDOM.render(eleByCreateElement, document.getElementById('root'));` javascript
【发上等愿,结中等缘,享下等福,择高处立,寻平处住,向宽处行】
