1、React介绍
1、react介绍
1.React简介
react是什么?
React 是一个用于构建用户界面的 JavaScript 库。
- 是一个将数据渲染为 HTML 视图的开源 JS 库
- 它遵循基于组件的方法,有助于构建可重用的 UI 组件
- 它用于开发复杂的交互式的 web 和移动 UI
React 有什么特点?
- 使用虚拟 DOM 而不是真正的 DOM
- 它可以用服务器渲染
- 它遵循单向数据流或数据绑定
- 高效
- 声明式编码,组件化编码
React 的一些主要优点?
- 它提高了应用的性能
- 可以方便在客户端和服务器端使用
- 由于使用 JSX,代码的可读性更好
- 使用React,编写 UI 测试用例变得非常容易
为什么学?
1.原生JS操作DOM繁琐,效率低
2.使用JS直接操作DOM,浏览器会进行大量的重绘重排
3.原生JS没有组件化编码方案,代码复用低
在学习之前最好看一下关于npm的知识:下面是我在网上看见的一个写的还不错的npm的文章
2.React 基础案例
首先需要引入几个 react 包
- React 核心库、操作 DOM 的 react 扩展库、将 jsx 转为 js 的 babel 库
【先引入react.development.js,后引入react-dom.development.js】
react.development.js
- react 是react核心库,只要使用react就必须要引入
- 下载地址:https://unpkg.com/react@18.0.0/umd/react.development.js
react-dom.development.js
- react-dom 是react的dom包,使用react开发web应用时必须引入
- 下载地址:https://unpkg.com/react-dom@18.0.0/umd/react-dom.development.js
babel.min.js
- 由于JSX最终需要转换为JS代码执行,所以浏览器并不能正常识别JSX,所以当我们在浏览器中直接使用JSX时,还必须引入babel来完成对代码的编译。
- babel下载地址:https://unpkg.com/babel-standalone@6/babel.min.js
react.development.js
react-dom.development.js
babel.min.js
2.创建一个容器
3.创建虚拟DOM,渲染到容器中
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<title>hello_react</title>
</head>
<body>
<!-- 准备好一个“容器” -->
<div id="test"></div>
<!-- 引入react核心库 -->
<script type="text/javascript" src="../js/react.development.js"></script>
<!-- 引入react-dom,用于支持react操作DOM -->
<script type="text/javascript" src="../js/react-dom.development.js"></script>
<!-- 引入babel,用于将jsx转为js -->
<script type="text/javascript" src="../js/babel.min.js"></script>
<script type="text/babel">
/* 此处一定要写babel */
//1.创建虚拟DOM
const VDOM = <h1>Hello</h1> /* 此处一定不要写引号,因为不是字符串 */
//2.渲染虚拟DOM到页面
const root = ReactDOM.createRoot(document.querySelector('#test'));
root.render(VDOM);
</script>
</body>
</html>
后面很多地方没有用
createRoot
这种方式是因为一开始学的课程是2020年的,这是现在新的创建方式。这里我就只把第一个案例改成新方式了
这样,就会在页面中的这个div容器上添加这个h1.
- React.createElement()
React.createElement(type, [props], [...children])
- 用来创建React元素
- React元素无法修改
- ReactDOM.createRoot()
createRoot(container[, options])
- 用来创建React的根容器,容器用来放置React元素
- ReactDOM.render()
root.render(element)
- 用来将React元素渲染到根元素中
- 根元素中所有的内容都会被删除,被React元素所替换
- 当重复调用render()时,React会将两次的渲染结果进行比较,
- 它会确保只修改那些发生变化的元素,对DOM做最少的修改
3.jsx 语法
JSX 是 JavaScript 的语法扩展,JSX 使得我们可以以类似于 HTML 的形式去使用 JS。JSX便是React中声明式编程的体现方式。声明式编程,简单理解就是以结果为导向的编程。使用JSX将我们所期望的网页结构编写出来,然后React再根据JSX自动生成JS代码。所以我们所编写的JSX代码,最终都会转换为以调用React.createElement()
创建元素的代码。
- 定义虚拟DOM,JSX不是字符串,不要加引号
- 标签中混入JS表达式的时候使用
{}
id = {myId.toUpperCase()}
- 样式的类名指定不能使用class,使用
className
- 内敛样式要使用
{{}}
包裹
style={{color:'skyblue',fontSize:'24px'}}
- 不能有多个根标签,只能有一个根标签
- JSX的标签必须正确结束(自结束标签必须写/)
- JSX中html标签应该小写,React组件应该大写开头。如果小写字母开头,就将标签转化为 html 同名元素,如果 html 中无该标签对应的元素,就报错;如果是大写字母开头,react 就去渲染对应的组件,如果没有就报错
- 如果表达式是空值、布尔值、undefined,将不会显示
关于JS表达式和JS语句:
- JS表达式:返回一个值,可以放在任何一个需要值的地方 a a+b demo(a) arr.map() function text(){}
- JS语句:if(){} for(){} while(){} swith(){} 不会返回一个值
{}:花括号中只能放表达式
其它
- 注释
写在花括号里
ReactDOM.render(
<div>
<h1>小丞</h1>
{/*注释...*/}
</div>,
document.getElementById('example')
);
class
需要使用className
代替style
中必须使用对象设置style={{background:'red'}}
<style>
.title{
background-color: orange;
width: 200px;
}
</style>
<!-- 准备好一个“容器” -->
<div id="test"></div>
<script type="text/babel" >
const myId = 'aTgUiGu'
const myData = 'HeLlo,rEaCt'
//1.创建虚拟DOM
const VDOM = (
<div>
<h2 className="title" id={myId.toLowerCase()}>
<span style={{color:'white',fontSize:'29px'}}>{myData.toLowerCase()}</span>
</h2>
<h2 className="title" id={myId.toLowerCase()}>
<span style={{color:'white',fontSize:'29px'}}>{myData.toUpperCase()}</span>
</h2>
<input type="text"/>
</div>
)
//2.渲染虚拟DOM到页面
ReactDOM.render(VDOM,document.getElementById('test'))
</script>
- 数组
JSX 允许在模板中插入数组,数组自动展开全部成员
{} 只能用来放js表达式,而不能放语句(if for)
在语句中是可以去操作JSX
var arr = [
<h1>小丞</h1>,
<h2>同学</h2>,
];
ReactDOM.render(
<div>{arr}</div>,
document.getElementById('example')
);
tip: JSX 小练习
根据动态数据生成 li
const data = ['A','B','C']
const VDOM = (
<div>
<ul>
{
data.map((item,index)=>{
return <li key={index}>{item}</li>
})
}
</ul>
</div>
)
ReactDOM.render(VDOM,document.querySelector('.test'))
4.两种创建虚拟DOM的方式
使用JSX创建虚拟DOM
//1.创建虚拟DOM /* 此处一定不要写引号,因为不是字符串 */
const VDOM = (
<h1 id="title">
<span>Hello,React</span>
</h1>
)
//2.渲染虚拟DOM到页面
ReactDOM.render(VDOM,document.querySelector('.test'))
这个在上面的案例中已经演示过了 ,下面看看另外一种创建虚拟DOM的方式
2.使用JS创建虚拟DOM
/*
* React.createElement()
* - 用来创建一个React元素
* - 参数:
* 1.元素的名称(html标签必须小写)
* 2.标签中的属性
* - class属性需要使用className来设置
* - 在设置事件时,属性名需要修改为驼峰命名法
* 3.元素的内容(子元素)
* - 注意点:
* React元素最终会通过虚拟DOM转换为真实的DOM元素
* React元素一旦创建就无法修改,只能通过新创建的元素进行替换
* */
//1.创建虚拟DOM,创建嵌套格式的dom
const VDOM=React.createElement('h1',{id:'title'},React.createElement('span',{},'hello,React'))
//2.渲染虚拟DOM到页面
ReactDOM.render(VDOM,document.querySelector('.test'))
使用JS和JSX都可以创建虚拟DOM,但是可以看出JS创建虚拟DOM比较繁琐,尤其是标签如果很多的情况下,所以还是比较推荐使用JSX来创建。
jsx语法规则总结:
1、定义虚拟dom时候,不要写引号
2、标签中混入js表达式时要用{}
3、样式的类名字指定不要用class 要用className
4、内敛样式使用style={{key:value.key:value}}方式定义样式
5、Jsx中跟标签只能有一个,如果存在多个并列的根标签,直接使用div进行包裹即可
6、标签必须进行闭合
7、标签首字母:
如果是小写字母开头,则react将标签转换为html中的同名元素,弱html中无改标签对应的同名元素,则报错。
如果是大写字母开头,react就去渲染对应的组件,如果没有定义该组件,就会报错
5.两种DOM的区别
<!-- 准备好一个“容器” -->
<div id="test"></div>
<script type="text/babel">
// 此处一定要写babel
//1.创建虚拟DOM /* 此处一定不要写引号,因为不是字符串 */
const VDOM = <h1>Hello,React</h1>
//2.渲染虚拟DOM到页面
ReactDOM.render(VDOM, document.getElementById('test'))
const TDOM = document.querySelector('#test')
console.log('虚拟DOM', VDOM)
console.dir('真实DOM')
console.dir(TDOM)
// debugger
console.log(typeof VDOM)
console.log(VDOM instanceof Object)
关于虚拟DOM:
本质是Object类型的对象(一般对象)
虚拟DOM比较“轻”,真实DOM比较“重”,因为虚拟DOM是React内部在用,无需真实DOM上那么多的属性,所以真实的DOM比虚拟的DOM多很多属性。
虚拟DOM最终会被React转化为真实DOM,呈现在页面上。
6、组件化编程
6.1、模块
什么是模块?
向外提供特定功能的js程序,一般是将一个大的js功能模块拆分成多个小的文件,一个文件就对应一个组件模块,
为什么要拆分成多个模块?
- 随着业务越来越复杂,代码逐渐变得非常臃肿,拆分组件可以服用js程序,简化js程序的编写,提高js运行效率。
6.2、组件
- 用来实现局部功能效果的代码和资源的合集(html,css,js,image)等资源
- 组件化开发可以让页面渲染的速度更快,服用代码逻辑,提高项目运行效率。
组件是比模块更高级的拆分,一个组件包含多个模块,是一个功能点的集合,比如一个导航栏,里面包含html,css,i=js,img,video,font等所有内容都属于一个组件的,全部封装组成一个组件的功能,这些功能组合在一起形成一个组件。
6.3、模块化
当应用的js都已模块来编写,这个应用就是一个模块化应用。
6.4、组件化
应用以多组件的方式实现。