React 零散知识记录

样式隔离

vue 中可以使用scoped属性实现样式隔离

javascript 复制代码
<style scoped>
</style>

但是在React 中如何实现呢,可以使用CSS Modules

CSS ModulesReact 生态中最主流的样式隔离方案,它会自动将类名编译为唯一哈希值,从根本上避免冲突。

前置条件

  • React 脚手架(Create React App、Vite)已内置 CSS Modules 支持,无需额外配置
  • CSS 文件命名必须遵循 [文件名].module.css 格式(比如 Button.module.css

缓存

创建持久化缓存

javascript 复制代码
import { create } from "zustand";
import { persist } from "zustand/middleware";

export const useLoginStore = create()(
    persist(
        (set) => ({
            userInfo: {},
            menuList: [],
            buttonList: [],
            dictList: [],

            setUserInfo: (userInfo) =>
                set((state) => ({
                    userInfo: { ...state.userInfo, ...userInfo },
                })),

            clearUserInfo: () =>
                set({
                    userInfo: {},
                }),

            setPermissions: ({ menuList, buttonList, dictList }) =>
                set((state) => ({
                    menuList: menuList ?? state.menuList,
                    buttonList: buttonList ?? state.buttonList,
                    dictList: dictList ?? state.dictList,
                })),

            clearStore: () => ({
                userInfo: {},
                menuList: [],
                buttonList: [],
                dictList: [],
            }),
        }),
        {
            name: "loginStore",
        }
    )
);

父组件调用子组件方法

注意:

  • 尽量少用这种方式:React 提倡单向数据流,父组件调用子组件方法属于 "反向操作",优先通过 props 传值 / 回调的方式实现交互
javascript 复制代码
import { Modal } from "antd";
import { useState, useImperativeHandle, forwardRef } from "react";

export interface MenuSearchDialogRef {
  openDialog: () => void;
  closeDialog: () => void;
}

// 用forwardRef 包装组件,使父组件可以调用子组件的方法
// 第一个参数是子组件的props,第二个参数是ref。props未使用可以用_代替
const MenuSearchDialog = forwardRef<MenuSearchDialogRef>((_, ref) => {
  // 控制弹窗的打开与关闭
  const [visible, setVisible] = useState(false);

  // 打开弹窗
  const openDialog = () => {
    setVisible(true);
  };

  // 关闭弹窗
  const closeDialog = () => {
    setVisible(false);
  };

  // 向父组件暴漏方法
  useImperativeHandle(ref, () => ({
    openDialog,
    closeDialog,
  }));

  return (
    <Modal
      title="菜单搜索"
      visible={visible}
      onCancel={closeDialog}
      footer={null}
    ></Modal>
  );
});

export default MenuSearchDialog;
相关推荐
freewlt2 小时前
前端性能优化实战:从 Lighthouse 分数到用户体验的全面升级
前端·性能优化·ux
小小亮012 小时前
Next.js基础
开发语言·前端·javascript
华洛2 小时前
我用AI做了一个48秒的真人精品漫剧,不难也不贵
前端·javascript·后端
Novlan13 小时前
我把 Claude Code 里的隐藏彩蛋提取出来了——零依赖的 ASCII 虚拟宠物系统
前端
IAUTOMOBILE3 小时前
Python 流程控制与函数定义:从调试现场到工程实践
java·前端·python
好大哥呀4 小时前
C++ Web 编程
开发语言·前端·c++
爱学习的小仙女!4 小时前
面试题 前端(一)DOCTYPE作用 标准模式与混杂模式区分
前端·前端面试题
小小小小宇5 小时前
前端转后端基础- 变量和类型
前端
Cobyte6 小时前
1.基于依赖追踪和触发的响应式系统的本质
前端·javascript·vue.js
主宰者6 小时前
C# CommunityToolkit.Mvvm全局事件
java·前端·c#