博客
关于我
Material UI框架下SnackBar(消息条)的高级用例--notistack
阅读量:803 次
发布时间:2019-03-25

本文共 2283 字,大约阅读时间需要 7 分钟。

使用React和Material UI的notistack组件实现高级消息条功能

一、介绍notistack

notistack 是 React 下基于 Material UI 的SnackBar 组件的高级封装,用来实现多个消息条的显示。它之所以备受欢迎,是因为其简单易用且功能丰富,能够满足大多数页面的消息显示需求,同时避免了为每个页面手动导入 Material UI 原生组件的麻烦。


二、安装依赖

1. 创建 React 项目

npx create-react-app notistackdemo

2. 安装相关库

cd notistackdemosudo npm install @material-ui/core --savesudo npm install @material-ui/icons --savesudo npm install notistack --save

三、初次使用

1. 初始化 SnackbarProvider

import React from 'react';import ReactDOM from 'react-dom';import './index.css';import App from './App';import * as serviceWorker from './serviceWorker';import { SnackbarProvider } from 'notistack';ReactDOM.render(  
, document.getElementById('root'));

2. 增加消息显示按钮

import React from 'react';import Button from '@material-ui/core/Button';import { useSnackbar } from 'notistack';function App() {  const { enqueueSnackbar } = useSnackbar();  const handleClick = (event) => {    enqueueSnackbar('消息内容', { variant: 'success' });  };  return (    
);}export default App;

四、高级功能示例

1. 自定义消息条数量和时间

// src/NotistackWrapper.jsconst MAX_SNACKBAR = 3;const AUTO_HIDE_DURATION = 3000;const POSITION = { vertical: 'bottom', horizontal: 'left' };export default function NotistackWrapper({ children }) {  return (    
{children}
);}

2. 移动端适配

npm install react-device-detect --save

五、消息条关闭回调

1. 定义回调函数

const handleClick = (event) => {  event.preventDefault();  enqueueSnackbar('消息内容', {    variant: 'success',    onClose: () => console.log('消息条关闭了')  });};

六、消息条关闭按钮

1. 增加关闭按钮

// src/NotistackWrapper.jsimport IconButton from '@material-ui/core/IconButton';import CloseIcon from '@material-ui/icons/Close';export default NotistackWrapper {  const onClickDismiss = (key) => {    notistackRef.current.closeSnackbar(key);  };  return (    
(
onClickDismiss(key)} >
)} > {children}
);}

七、总结

notistack 是一个功能强大的消息条组件,能够在 React 应用中无缝实现多个消息条的显示。通过简单的配置,可以实现消息条的定位、定时自动隐藏以及自定义样式等功能。在实际使用中,建议谨慎使用闭包回调函数,并结合 Material UI 统一风格进行界面设计,以提升用户体验。


提示与注意事项

  • src/index.js 中保证 SnackbarProvider 正确嵌入。
  • 对于移动端适配,建议使用 react-device-detect 来判断设备类型。
  • 确保关闭回调函数的唯一性,避免误操作。
  • 鼓励在项目启动前仔细阅读 notistack 的官方文档,以充分利用其功能。
  • 转载地址:http://ltpyk.baihongyu.com/

    你可能感兴趣的文章
    mysql判断某一张表是否存在的sql语句以及方法
    查看>>
    mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
    查看>>
    mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
    查看>>
    mysql加强(2)~单表查询、mysql查询常用的函数
    查看>>
    mysql加强(3)~分组(统计)查询
    查看>>
    mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
    查看>>
    mysql加强(5)~DML 增删改操作和 DQL 查询操作
    查看>>
    mysql加强(6)~子查询简单介绍、子查询分类
    查看>>
    mysql加强(7)~事务、事务并发、解决事务并发的方法
    查看>>
    MySQL千万级多表关联SQL语句调优
    查看>>
    mysql千万级大数据SQL查询优化
    查看>>
    MySQL千万级大表优化策略
    查看>>
    MySQL单实例或多实例启动脚本
    查看>>
    MySQL压缩包方式安装,傻瓜式教学
    查看>>
    MySQL原理、设计与应用全面解析
    查看>>
    MySQL原理简介—1.SQL的执行流程
    查看>>
    MySQL原理简介—10.SQL语句和执行计划
    查看>>
    MySQL原理简介—11.优化案例介绍
    查看>>
    MySQL原理简介—12.MySQL主从同步
    查看>>
    MySQL原理简介—2.InnoDB架构原理和执行流程
    查看>>