当前位置: 首页 > news >正文

react学习

一、react基础

  1. jsx
    大括号的作用
    在这里插入图片描述
{count}
{userLlist.map((item)=>{return <li key={item.id}>{item.name}</li>}) }
key是用于react内部渲染处理的
  1. 基础条件渲染
{flag && <p>{"显示"}</p>}
  1. 复杂条件渲染
function getItem(){if(type==1) return <p>有图模式<p/>else if(type==2) return <>无图</>}

2、useState使用
state是状态变量,数据变化视图变化

const [userList,setUserList]=useState([{id:1,name:"z"}])

3.map,filter函数使用

4.tab切换功能实现

const tab={{type:" ",text:" "}}
//将type设为class高亮

在这里插入图片描述

5.loadsh使用排序

import * as _ from 'lodash'
setCommentList(_.orderby(commentList,'star'//字段名,'desc'))
//不改变原数组

6.classnames优化类名控制
在这里插入图片描述
7.受控绑定表单

<input value={value} onChange={(e)=>{setValue(e.target.value); //显示输入}}type='text'/>

8.ref获取DOM对象

const inputRef=useRef(null);
<input ref={inputRef}/>
//使用inputRef.current获取DOM对象

9.uuid和dayjs库的使用
在这里插入图片描述

10.props使用

用于父传子组件消息

function Son(prop){prop.nameprop.children //特殊属性
}
function Father(prop){return <Son name="xxx"><p>this is span<p/></Son>
}

在这里插入图片描述
11.子传父,兄弟之间传消息(利用子传父,父传兄弟)

12.使用Context跨层通信

1、全局中createContext创建一个Context上下文对象
2、上层用<Context.Provider value={mdg}></>传递数据
3、底层用useContext(Context)方法获取数据

*13.UseEffect

在这里插入图片描述
在这里插入图片描述

    const [commentList,setCommentList]=useState([])useEffect(()=>{async function getCommentList(){// async异步,await等待const res=await fetch('/comment').then(res=>res.json().then(data=>{console.log(data);return data}))   setCommentList(res);}getCommentList()},[])

在这里插入图片描述
清除副作用,最常见是在组件卸载时候
在这里插入图片描述
14.自定义hook

  1. 构造一个use开头的函数名
  2. 在函数体内封装可复用的逻辑
  3. 把组件中用到的状态变量return出去
    在这里插入图片描述
  4. 使用时解构出来
    在这里插入图片描述

15.hook使用规则

1.组件外使用 x
2.if,for循环内使用 x

16.json-server和axios使用
在这里插入图片描述

二、 react使用redux

在这里插入图片描述

在这里插入图片描述
在我们继续之前,你需要熟悉一些重要的 Redux 术语:

  • state
  • action,action 是一个具有 type 字段的普通 JavaScript 对象
  • reducer是一个函数,接收当前的 state 和一个 action 对象,必要时决定如何更新状态,并返回新状态。函数签名是:(state, action) => newState。 你可以将 reducer 视为一个事件监听器,它根据接收到的 action(事件)类型处理事件。
  • dispatch,调用action
  • selector
    在这里插入图片描述

三、美团外卖项目

在这里插入图片描述

  1. 添加按钮怎么显示?
    解决方法:antd icon在这里插入图片描述
    在这里插入图片描述
  2. 滚动菜单如何实现
    解决方法:将延长的区域设置overflow:auto
  3. flex
    flex:1 不管内容多少,一般都是平分空间,空间大小都一致、
    而 flex:auto 是根据内容的大小来分,不是平的(除非内容都是一样,才平分)

完成页面制作

在这里插入图片描述

使用redux渲染页面

完成购物车功能
在这里插入图片描述

store.js
// 编写storeimport { createSlice } from "@reduxjs/toolkit"
import axios from "axios"const foodsStore = createSlice({name: 'foods',initialState: {// 商品列表foodsList: [],// 菜单激活下标值activeIndex: 0,// 购物车列表cartList: []},reducers: {// 更改商品列表setFoodsList (state, action) {// payload是传入的值state.foodsList = action.payload},changeActiveIndex(state,action){state.activeIndex = action.payload},addCart (state, action) {// 是否添加过?以action.payload.id去cartList中匹配 匹配到了 添加过const item = state.cartList.find(item => item.id === action.payload.id)if (item) {item.count++} else {state.cartList.push(action.payload)}},// count增increCount (state, action) {// 关键点:找到当前要修改谁的count idconst item = state.cartList.find(item => item.id === action.payload.id)item.count++},// count减decreCount (state, action) {// 关键点:找到当前要修改谁的count idconst item = state.cartList.find(item => item.id === action.payload.id)if (item.count === 0) {return}item.count--},clearCart(state){state.cartList=[];},}
})// 异步获取部分
const { setFoodsList, changeActiveIndex, addCart, increCount, decreCount, clearCart } = foodsStore.actions
const fetchFoodsList = () => {return async (dispatch) => {// 编写异步逻辑const res = await axios.get('meituan/menu')// 调用dispatch函数提交actiondispatch(setFoodsList(res.data))}
}export { fetchFoodsList, changeActiveIndex, addCart, increCount, decreCount, clearCart }const reducer = foodsStore.reducerexport default reducer

使用react-router-dom

  1. 制作路由表
const router = createBrowserRouter([{path:"login",element:<DempPage/>},{path:"index",element:<DempPage/>}
])
  • 声明式导航
<Link to='/index'  />
  • 编程式导航
useNavigate()
  • Routes 多个Route需要Route包起来
  • Route
  • Outle 给children占位

评价

在这里插入图片描述

在img标签里面只设置宽度,不设置高度,图片就会等比例缩放。
http://www.lryc.cn/news/272951.html

相关文章:

  • vue-cli项目中vue.config.js的配置
  • Github 2024-01-04 开源项目日报 Top10
  • 使用GPTs+Actions自动获取第三方数据
  • git提交操作(不包含初始化仓库)
  • 使用YOLOv8和Grad-CAM技术生成图像热图
  • Vue: 多个el-select不能重复选择相同属性
  • 金色麦芒的2023
  • java设计模式学习之【策略模式】
  • Mybatis SQL构建器类 - SqlBuilder and SelectBuilder (已经废弃)
  • 【Linux】不常用命令记录
  • 【docker】安装docker环境并启动容器
  • AIOps探索 | 基于大模型构建高效的运维知识及智能问答平台(2)案例分享
  • 【ESP32接入国产大模型之文心一言】
  • 保湿剂,预计2026年市场规模将达到约230亿美元
  • CodeWhisperer:编码世界中的声音启迪者
  • golang学习专栏
  • el-table表格动态添加列。多组数据拼接和多层级数据的处理
  • ThinkPHP6.0任意文件上传 PHPSESSION 已亲自复现
  • 短说社区运营的使用工具分享(一)
  • 关于.gitignore文件
  • Cell 文章图复现
  • 只需一招彻底解决SOLIDWORKS不显示缩略图预览
  • nccl 源码分析 从 ncclAllReduce 的执行开始认识nccl源代码
  • 仿照AirDrop(隔空投送)优雅地在局域网中传输文件
  • 【PHP】TP5.0及Fastadmin中将查询数据返回对象转为数组
  • 大公司里怎样开发和部署前端代码?
  • API接口:原理、设计与实践
  • 2023年TIOBE指数TOP50的编程语言写“Hello World!”
  • spring、springmvc、springboot、springcloud简介
  • 立仪科技光谱共焦位移传感器:应用领域的广泛性