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;
相关推荐
开飞机的舒克_21 分钟前
vue3+router动态权限路由
前端·vue.js
VitoChang21 分钟前
放弃手搓路由吧!用 SolidStart 搞 SPA,真香
前端
GuWenyue21 分钟前
告别JS类型坑!Ts为什么在ai时代逐渐成为"第一"语言
前端·算法·typescript
三乐22824 分钟前
事件循环是什么东西,一篇文章带你了解
前端·javascript
wuhen_n25 分钟前
RAG 核心:向量嵌入与本地向量数据库实战
前端·langchain·ai编程
孟陬26 分钟前
国外技术周刊 #139:LLM 正在杀死程序员的「懒惰美德」
前端·人工智能·后端
lichenyang45335 分钟前
补充:Repeat 虚拟滚动与 cachedCount 到底怎么用
前端
七牛云行业应用35 分钟前
Codex CLI 和 Codex 桌面端完整教程:两种入口的功能对比与选择指南
前端·后端·github
kisshyshy36 分钟前
告别 Node 噩梦?用 Bun + TypeScript 像写诗一样调用大模型
前端·typescript
wuhen_n37 分钟前
RAG 关键环节:文本分块策略与最优参数配置
前端·langchain·ai编程