IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 61 react -> 正文阅读

[JavaScript知识库]61 react

#react`

下载

npx create-react-app <name>

两种组件创建方式

函数组件

const App = () => {
    return ()
}

class 类组件

import React from 'react'

class App extends React.Component {
    render() {
        return ()
    }
}

UI 渲染

import ReactDOM from 'react-dom'
import App from './App'

ReactDom.render(
	<App />,
    document.querySelector('#root')
)

生命周期钩子函数

只适用于 class 类组件

创建时(挂载阶段)

钩子函数触发时机作用
constructor创建组件时,最先执行初始化 state,为事件处理程序绑定this
render每次组件渲染都会触发渲染 UI
componentDidMount组件挂载(完成DOM渲染)后发送 ajax 请求,DOM 操作

更新时(更新阶段)

钩子函数触发时机作用
rendersetState()forceUpdate(), new props重新渲染 UI
componentDidUpdate(prevprops)组件更新(完成 DOM 渲染)后发送 ajax 请求,DOM 操作,setState() 必须放在 if 条件中

卸载时(卸载阶段)

钩子函数触发时机作用
componentWillUnmount组件卸载(从页面中消失)执行清理工作

Hooks

只适用于函数组件,可以使用 useEffect 模拟 class 类组件的生命周期钩子函数

useState

状态管理

import { useState } from 'react'

const [num, setNum] = useState(0)
const handleClick = () => {
	setNum(num + 1)
}
const App = () => {
    return (
        <>
            <h1>{ num }</h1
            <button onClick={ handleClick }>点击加1</button>
		</>
    )
}

useEffect

可用于模拟 class 类组件的生命周期钩子函数

import { useState, useEffect } from 'react'

const [num, setNum] = useState(0)
useEffect(() => {
    console.log('模拟 componentDidMount + componentDidUpdate')
})
useEffect(() => {
    console.log('模拟 componentDidMount')
}, [])
useEffect(() => {
    console.log('模拟 compinentDidMount + componentDidUpdate 且只依赖于 num 的更新')
}, [num])
useEffect(() => {
    return () => {
        console.log('模拟 componentWillUnmount')
	}
})
const App = () => {
    return (
        <p>App</p>
    )
}

useNavigate

用于编程式导航,适用于新版本 react-router

import { useNavigate } from 'react-router-dom'

const navigate = useNavigate()
const handleClick = () => {
    navigate('/home', { push: true })
}
const App = () => {
    return (
    	<button onClick={ handleClick }>点击跳转到Home</button>
    )
}

useHistory

用于编程式导航,适用于旧版本 react-router

import { useHistory } from 'react-router-dom'

const history = useHistory()
const handleClick = () => {
    history.push('/home')
}
const App = () => {
    return (
    	<button onClick={ handleClick }>点击跳转到Home</button>
    )
}

组件通信

父传子

import ReactDOM from 'react-dom'
import { useState } from 'react'

const Father = () => {
    const [fatherData, setFatherData] = useState({
        dataFrom: 'father',
    })
    return <Son fatherMsg={fatherData} />
}

const Son = props => {
    console.log('父组件传递过来的数据:', props.fatherMsg)
    return (
    	<p>son</p>
    )
}

ReactDOM.render(
    <Fatehr />,
    document.querySelector('#root')
)

子传父

import ReactDOM from 'react-dom'
import { useState } from 'react'

const Father = () => 
	const handleGetData = msg => {
    	console.log('子组件传递过来的数据:', msg)
    }
    return <Son getSonData={handleGetData} />
}

const Son = props => {{
    const [sonData, setSonData] = useState({
        dataFrom: 'son',
    })
    const handleClick = () => {
        props.getSonData(sonData)
    }
    return (
        <>
    		<p>son</p>
        	<button onClick={handleClick}>点击发送数据</button>
        </>
    )
}

ReactDOM.render(
    <Fatehr />,
    document.querySelector('#root')
)

跨层级通信

import ReactDOM from 'react-dom'
import { useState, createContext } from 'react'

const { Provider, Consumer } = createContext()
const GrandPa= () => {
  const [data, setData] = useState({
    from: 'grandpa',
  })
  return (
    <Provider value={data}>
      <Father />
    </Provider>
  )
}

const Father = () => {
    return <Son />
}

const Son = () => {
  return (
    <Consumer>
      {
        data => <p>{ data.from }</p>
      }
    </Consumer>
  )
}

ReactDOM.render(
      <GrandPa />,
    document.querySelector('#root')
)

react-router

下载

npm i react-router-dom

使用

使用 react-router 必须使用 BrowserRouterHashRouter 包裹

import ReactDOM from 'react-dom'
import App from './App'
import { BrowserRouter as Router } from 'react-router-dom'

ReactDOM.render(
	<Router>
    	<App />
    </Router>,
    doucment.querySelector('#root')
)

导航

点击导航

import { Link } from 'react-router-dom'

<Link to='/home'>点击跳转到Home</Link>

编程式导航

高版本使用 useNavigate ,低版本使用 useHistory

路由

新版本

import { Routes, Route } from 'react-router-dom'
import Home from './pages/home'

<Routes>
    <Route path='/home' element={<Home />} />
</Routes>

路由和渲染路由分离

路由
import Home from '../pages/home'

const routes = [
    {
        name: 'home',
        path: '/home',
        element: Home,
    }
]

export default routes
渲染路由函数
import { Routes, Route } from 'react-router-dom'

const renderRoutes = routes => {
    return (
    	<Routes>
        	{
                routes.map(route => {
                    return (
                    	<Route key={route.name} path={route.path} element={<route.element />} />
                    )
                })
            }
        </Routes>
    )
}

export default renderRoutes
渲染路由
import routes from './ulits/routes'
import renderRoutes from './ulits/renderRoutes'

const App = () => {
    return (
        <Link to='/home'>点击跳转到Home</Link>
    	renderRoutes(routes)
    )
}

旧版本

import { Switch, Route } from 'react-router-dom'
import Home from './pages/home'

<Switch>
    <Route path='/home' component={Home} />
</Switch>

redux

下载

npm i redux react-redux

使用

使用 redux 必须使用 Provider 包裹

import ReactDOM from 'react-dom'
import App from './App'
import store from './redux/store'
import { Proider } from 'react-redux'

ReactDOM.render(
	<Provider store={store}>
    	<App />
    </Provider>,
    doucment.querySelector('#root')
)

三大原则

单一数据源

state 是只读的

使用纯函数修改数据

核心

actions

const action = () => {
    return {
        type: 'count'
    }
}

module.exports = {
    action,
}

reducers

const initState = {
    count: 0,
}

const reducer = (state=initState, action) => {
    switch(action.type) {
        case 'count':
            return {
                count: state.count + 1
            }
        default:
            retun state
    }
}

module.exports = {
    reducer,
}

store

import { combineReducers, createStore } feom 'redux'
import { reducer } from '../reducer'

cosnt reducers = combineReducers({
    reducer,
})

cosnt store = createStore(reducers)

export default store

数据的发送与获取

connect

import { connect } from 'react-redux'
import { action } from './redux/action'

const App = props => {
    retun (
        <>
        	<p>计数器:{ props.reducer.count }</p>
        </>
    )
}

const actionObj = action()
const mapStateToProps = state => {
    return state
}
const mapDispatchToProps = dispatch => {
    return {
        action: () => {
            dispatch(actionObj)
        }
    }
}

export default connect(mapStateToProps, mapDispatchToProps)(App)
ps => {
    retun (
        <>
        	<p>计数器:{ props.reducer.count }</p>
        </>
    )
}

const actionObj = action()
const mapStateToProps = state => {
    return state
}
const mapDispatchToProps = dispatch => {
    return {
        action: () => {
            dispatch(actionObj)
        }
    }
}

export default connect(mapStateToProps, mapDispatchToProps)(App)
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-24 00:26:06  更:2022-03-24 00:27:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:49:29-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码