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;
相关推荐
UXbot3 小时前
AI原型设计工具如何支持团队协作与快速迭代
前端·交互·个人开发·ai编程·原型模式
ZC跨境爬虫4 小时前
跟着MDN学HTML_day_48:(Node接口)
前端·javascript·ui·html·音视频
红尘散仙5 小时前
一套 Rust 核心,跑通 Tauri + React Native
react native·react.js·rust
PieroPc5 小时前
CAMWATCH — 局域网摄像头监控系统 Fastapi + html
前端·python·html·fastapi·监控
巴巴博一6 小时前
2026 最新:Trae / Cursor 一键接入 taste-skill 完整教程(让 AI 前端告别“AI 味”)
前端·ai·ai编程
kyriewen6 小时前
半夜三点线上崩了,AI替我背了锅——用AI排错,五分钟定位三年老bug
前端·javascript·ai编程
kyriewen7 小时前
我让 AI 当了 24 小时全年无休的“毒舌考官”
前端·ci/cd·ai编程
hexu_blog7 小时前
vue+java实现图片批量压缩
java·前端·vue.js
IT_陈寒7 小时前
为什么你应该学习JavaScript?
前端·人工智能·后端
lifejump7 小时前
Empire(帝国)CMS 7.5 XSS注入
前端·安全·xss