前言 | ❤️ 只有与自己和解,故事才会翻到下一页 ❤️ |
---|
1️⃣ React
是一个用于构建用户界面的 JavaScript 库。
2️⃣ React
主要用来写HTML页面,或构建Web应用。如果从 MVC 的角度来看,React 仅仅是视图层(V),也就是只负责视图的渲染,而并非提供了完整的 M 和 C 的功能。
3️⃣ React
起源于 Facebook 的内部项目,用来架设 Instagram 的网站,并于 2013 年 5 月开源。
1️⃣ 你只需要描述 UI(HTML)看起来是什么样,就跟写HTML一样;
2️⃣ React
负责渲染 UI,并在数据变化时更新 UI;
代码演示如下:
const jsx = <div className="app">
<h1>Hello React! 动态变化数据:{count}</h1>
</div>
React
最重要的内容;React
构建组件,使得代码更加容易得到复用,能够很好的应用在大项目的开发中;安装命令:npm i react react-dom
react
包是核心,提供创建元素、组件等功能react-dom
包提供 DOM 相关功能等1️⃣ 引入 react
和 react-dom
两个 js 文件;
2️⃣ 创建 React
元素;
3️⃣ 渲染 React
元素到页面中;
完整代码演示如下:
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>react基本使用title>
head>
<body>
<div id="root">div>
<script src="./node_modules/react/umd/react.development.js">script>
<script src="./node_modules/react-dom/umd/react-dom.development.js">script>
<script>
// 2 创建react元素
// 参数一:元素名称
// 参数二:元素属性
// 参数三:元素的子节点
const title = React.createElement('h1', null, 'Hello React')
// 3 渲染react元素
// 参数一:要渲染的react元素
// 参数二:挂载点
ReactDOM.render(title, document.getElementById('root'))
script>
body>
html>
// 返回值:React元素
// 第一个参数:要创建的React元素名称
// 第二个参数:该React元素的属性
// 第三个及其以后的参数:该React元素的子节点
const el = React.createElement('h1', { title: '标题' }, 'Hello React')
ReactDOM.render()
说明// 第一个参数:要渲染的React元素
// 第二个参数:DOM对象,用于指定渲染到页面中的位置
ReactDOM.render(el, document.getElementById('root'))
npx 命令介绍:
1️⃣ 导入 react
和 react-dom
两个包;
import React from 'react'
import ReactDOM from 'react-dom'
2️⃣ 调用 React.createElement() 方法创建 react
元素;
3️⃣ 调用 ReactDOM.render()
方法渲染 react
元素到页面中;
1️⃣ JSX
是 JavaScript XML 的简写,表示在 JavaScript 代码中写 XML(HTML) 格式的代码。
2️⃣ 优势:声明式语法更加直观、与HTML结构相同,降低了学习成本、提升开发效率。
3️⃣ JSX
是 React 的核心内容。
1️⃣ 使用 JSX
语法创建 react
元素;
// 使用 JSX 语法,创建 react 元素:
const title = <h1>Hello JSX</h1>
2️⃣ 使用 ReactDOM.render()
方法渲染 react
元素到页面中;
// 渲染react元素
ReactDOM.render(title, document.getElementById('root'))
思考:为什么脚手架中可以使用 JSX 语法?:
React
元素的属性名使用驼峰命名法。完整代码演示如下:
import React from 'react'
import ReactDOM from 'react-dom'
/*
JSX中使用JavaScript表达式
*/
const name = 'Jack'
const age = 19
const title = (
<h1>
Hello JSX, {name}, 年龄:{age}
</h1>
)
// 渲染react元素
ReactDOM.render(title, document.getElementById('root'))
完整代码演示如下:
import React from 'react'
import ReactDOM from 'react-dom'
/*
条件渲染:
*/
const isLoading = false
// if-else:
// const loadData = () => {
// if (isLoading) {
// return loading...
// }
// return 数据加载完成,此处显示加载后的数据
// }
// 三元表达式:
// const loadData = () => {
// return isLoading ? (loading...) : (数据加载完成,此处显示加载后的数据)
// }
// 逻辑与运算符:
const loadData = () => {
return isLoading && (<div>loading...</div>)
}
const title = (
<h1>
条件渲染:
{loadData()}
</h1>
)
// 渲染react元素
ReactDOM.render(title, document.getElementById('root'))
完整代码演示如下:
import React from 'react'
import ReactDOM from 'react-dom'
/*
列表渲染:
*/
// 歌曲列表:
const songs = [
{ id: 1, name: '海阔天空' },
{ id: 2, name: '光辉岁月' },
{ id: 3, name: '冷雨夜' },
]
const list = (
<ul>
{songs.map(item => <li key={item.id}>{item.name}</li>)}
</ul>
)
// 渲染react元素
ReactDOM.render(list, document.getElementById('root'))
代码演示如下:
<h1 style={{ color: 'red', backgroundColor: 'skyblue' }}>
JSX的样式处理
</h1>
代码演示如下:
<h1 className="title">
JSX的样式处理
</h1>
由于内容较多,所以我决定分开写啦,我会坚持一直更新呢!喜欢的朋友们记得点点赞哦!