2016-08-17 11:07:02 +08:00
---
category: Components
2022-11-09 12:28:04 +08:00
group: Feedback
2016-08-17 11:07:02 +08:00
noinstant: true
2016-09-09 13:55:46 +08:00
title: Notification
2024-03-22 14:22:42 +08:00
description: Prompt notification message globally.
2024-01-29 14:50:36 +08:00
cover: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*cRmqTY4nKPEAAAAAAAAAAAAADrJ8AQ/original
coverDark: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*W3RmSov-xVMAAAAAAAAAAAAADrJ8AQ/original
2022-11-09 12:28:04 +08:00
demo:
cols: 2
2016-08-17 11:07:02 +08:00
---
2016-09-10 13:43:30 +08:00
## When To Use
2017-10-25 10:25:44 +08:00
2019-05-07 14:57:32 +08:00
To display a notification message at any of the four corners of the viewport. Typically it can be used in the following cases:
2016-08-17 11:07:02 +08:00
- A notification with complex content.
2019-05-07 14:57:32 +08:00
- A notification providing a feedback based on the user interaction. Or it may show some details about upcoming steps the user may have to follow.
2016-08-17 11:07:02 +08:00
- A notification that is pushed by the application.
2022-11-09 12:28:04 +08:00
## Examples
2022-11-17 17:31:26 +08:00
<!-- prettier - ignore -->
2022-11-09 12:28:04 +08:00
< code src = "./demo/hooks.tsx" > Hooks usage (recommended)< / code >
< code src = "./demo/duration.tsx" > Duration after which the notification box is closed< / code >
< code src = "./demo/with-icon.tsx" > Notification with icon< / code >
< code src = "./demo/with-btn.tsx" > Custom close button< / code >
< code src = "./demo/custom-icon.tsx" > Customized Icon< / code >
< code src = "./demo/placement.tsx" > Placement< / code >
< code src = "./demo/custom-style.tsx" > Customized style< / code >
< code src = "./demo/update.tsx" > Update Message Content< / code >
2023-09-13 15:19:18 +08:00
< code src = "./demo/stack.tsx" version = "5.10.0" > Stack< / code >
2024-05-17 15:39:30 +08:00
< code src = "./demo/show-with-progress.tsx" version = "5.18.0" > Show with progress< / code >
2023-05-18 23:53:34 +08:00
< code src = "./demo/basic.tsx" > Static Method (deprecated)< / code >
2022-11-09 12:28:04 +08:00
< code src = "./demo/render-panel.tsx" debug > _InternalPanelDoNotUseOrYouWillBeFired< / code >
2016-08-17 11:07:02 +08:00
## API
2023-08-08 18:27:48 +08:00
Common props ref: [Common props](/docs/react/common-props)
2016-08-17 11:07:02 +08:00
- `notification.success(config)`
- `notification.error(config)`
- `notification.info(config)`
- `notification.warning(config)`
2018-07-18 14:55:47 +08:00
- `notification.open(config)`
2022-05-11 14:26:18 +08:00
- `notification.destroy(key?: String)`
2016-08-17 11:07:02 +08:00
The properties of config are as follows:
2023-05-19 18:21:31 +08:00
| Property | Description | Type | Default | Version |
| --- | --- | --- | --- | --- |
| btn | Customized close button | ReactNode | - | - |
| className | Customized CSS class | string | - | - |
2024-02-01 10:36:21 +08:00
| closeIcon | Custom close icon | ReactNode | true | 5.7.0: close button will be hidden when setting to null or false |
2023-05-19 18:21:31 +08:00
| description | The content of notification box (required) | ReactNode | - | - |
| duration | Time in seconds before Notification is closed. When set to 0 or null, it will never be closed automatically | number | 4.5 | - |
2024-05-17 15:39:30 +08:00
| showProgress | Show progress bar for auto-closing notification | boolean | | 5.18.0 |
2024-05-27 13:35:37 +08:00
| pauseOnHover | keep the timer running or not on hover | boolean | true | 5.18.0 |
2023-05-19 18:21:31 +08:00
| icon | Customized icon | ReactNode | - | - |
| key | The unique identifier of the Notification | string | - | - |
| message | The title of notification box (required) | ReactNode | - | - |
2025-01-16 10:31:16 +08:00
| placement | Position of Notification, can be one of `top` \| `topLeft` \| `topRight` \| `bottom` \| `bottomLeft` \| `bottomRight` | string | `topRight` | - |
2023-05-19 18:21:31 +08:00
| style | Customized inline style | [CSSProperties ](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/e434515761b36830c3e58a970abf5186f005adac/types/react/index.d.ts#L794 ) | - | - |
| role | The semantics of notification content recognized by screen readers. The default value is `alert` . When set as the default value, the screen reader will promptly interrupt any ongoing content reading and prioritize the notification content for immediate attention. | `alert \| status` | `alert` | 5.6.0 |
| onClick | Specify a function that will be called when the notification is clicked | function | - | - |
| onClose | Trigger when notification closed | function | - | - |
| props | An object that can contain `data-*` , `aria-*` , or `role` props, to be put on the notification `div` . This currently only allows `data-testid` instead of `data-*` in TypeScript. See https://github.com/microsoft/TypeScript/issues/28960. | Object | - | - |
2016-08-17 11:07:02 +08:00
2023-05-12 09:53:00 +08:00
- `notification.useNotification(config)`
The properties of config are as follows:
| Property | Description | Type | Default | Version |
| --- | --- | --- | --- | --- |
2024-01-25 23:45:43 +08:00
| bottom | Distance from the bottom of the viewport, when `placement` is `bottom` `bottomRight` or `bottomLeft` (unit: pixels) | number | 24 | |
2024-02-01 10:36:21 +08:00
| closeIcon | Custom close icon | ReactNode | true | 5.7.0: close button will be hidden when setting to null or false |
2023-06-12 14:20:10 +08:00
| getContainer | Return the mount node for Notification | () => HTMLNode | () => document.body | |
2025-01-16 10:31:16 +08:00
| placement | Position of Notification, can be one of `top` \| `topLeft` \| `topRight` \| `bottom` \| `bottomLeft` \| `bottomRight` | string | `topRight` | |
2024-07-23 20:15:15 +08:00
| showProgress | Show progress bar for auto-closing notification | boolean | | 5.18.0 |
| pauseOnHover | keep the timer running or not on hover | boolean | true | 5.18.0 |
2023-05-12 09:53:00 +08:00
| rtl | Whether to enable RTL mode | boolean | false | |
2023-09-13 15:19:18 +08:00
| stack | Notifications will be stacked when amount is over threshold | boolean \| `{ threshold: number }` | `{ threshold: 3 }` | 5.10.0 |
2024-01-25 23:45:43 +08:00
| top | Distance from the top of the viewport, when `placement` is `top` `topRight` or `topLeft` (unit: pixels) | number | 24 | |
2023-05-12 09:53:00 +08:00
| maxCount | Max Notification show, drop oldest if exceed limit | number | - | 4.17.0 |
2017-09-11 11:08:34 +08:00
`notification` also provides a global `config()` method that can be used for specifying the default options. Once this method is used, all the notification boxes will take into account these globally defined options when displaying.
2016-08-17 11:07:02 +08:00
2023-02-15 15:05:21 +08:00
### Global configuration
2017-10-25 10:25:44 +08:00
2023-02-15 15:05:21 +08:00
`notification.config(options)`
> When you use `ConfigProvider` for global configuration, the system will automatically start RTL mode by default.(4.3.0+)
>
> When you want to use it alone, you can start the RTL mode through the following settings.
#### notification.config
2020-04-30 10:52:44 +08:00
2016-08-17 11:07:02 +08:00
```js
notification.config({
2017-01-27 17:12:25 +08:00
placement: 'bottomRight',
bottom: 50,
2016-08-17 11:07:02 +08:00
duration: 3,
2020-04-13 15:45:49 +08:00
rtl: true,
2016-08-17 11:07:02 +08:00
});
```
2021-11-12 11:46:42 +08:00
| Property | Description | Type | Default | Version |
2021-08-17 10:45:33 +08:00
| --- | --- | --- | --- | --- |
2024-01-25 23:45:43 +08:00
| bottom | Distance from the bottom of the viewport, when `placement` is `bottom` `bottomRight` or `bottomLeft` (unit: pixels) | number | 24 | |
2024-02-01 10:36:21 +08:00
| closeIcon | Custom close icon | ReactNode | true | 5.7.0: close button will be hidden when setting to null or false |
2021-11-12 11:46:42 +08:00
| duration | Time in seconds before Notification is closed. When set to 0 or null, it will never be closed automatically | number | 4.5 | |
2023-06-07 13:49:31 +08:00
| getContainer | Return the mount node for Notification, but still display at fullScreen | () => HTMLNode | () => document.body | |
2024-01-25 23:45:43 +08:00
| placement | Position of Notification, can be one of `top` `topLeft` `topRight` `bottom` `bottomLeft` `bottomRight` | string | `topRight` | |
2024-07-23 20:15:15 +08:00
| showProgress | Show progress bar for auto-closing notification | boolean | | 5.18.0 |
| pauseOnHover | keep the timer running or not on hover | boolean | true | 5.18.0 |
2021-11-12 11:46:42 +08:00
| rtl | Whether to enable RTL mode | boolean | false | |
2024-01-25 23:45:43 +08:00
| top | Distance from the top of the viewport, when `placement` is `top` `topRight` or `topLeft` (unit: pixels) | number | 24 | |
2021-11-12 11:46:42 +08:00
| maxCount | Max Notification show, drop oldest if exceed limit | number | - | 4.17.0 |
2020-02-07 17:55:27 +08:00
2023-04-11 10:25:24 +08:00
## Design Token
< ComponentTokenTable component = "Notification" > < / ComponentTokenTable >
2020-02-07 17:55:27 +08:00
## FAQ
2022-11-29 10:39:57 +08:00
### Why I can not access context, redux, ConfigProvider `locale/prefixCls/theme` in notification?
2020-02-07 17:55:27 +08:00
2020-02-07 20:32:00 +08:00
antd will dynamic create React instance by `ReactDOM.render` when call notification methods. Whose context is different with origin code located context.
2020-02-07 17:55:27 +08:00
When you need context info (like ConfigProvider context), you can use `notification.useNotification` to get `api` instance and `contextHolder` node. And put it in your children:
```tsx
const [api, contextHolder] = notification.useNotification();
return (
< Context1.Provider value = "Ant" >
2020-03-30 16:17:12 +08:00
{/* contextHolder is inside Context1 which means api will get value of Context1 */}
2020-02-07 17:55:27 +08:00
{contextHolder}
< Context2.Provider value = "Design" >
2020-03-30 16:17:12 +08:00
{/* contextHolder is outside Context2 which means api will **not** get value of Context2 */}
2020-02-07 17:55:27 +08:00
< / Context2.Provider >
< / Context1.Provider >
);
```
**Note:** You must insert `contextHolder` into your children with hooks. You can use origin method if you do not need context connection.
2021-02-09 21:49:15 +08:00
2022-12-26 11:55:18 +08:00
> [App Package Component](/components/app) can be used to simplify the problem of `useNotification` and other methods that need to manually implant contextHolder.
2022-12-26 10:08:15 +08:00
2021-02-09 21:49:15 +08:00
### How to set static methods prefixCls ?
2022-12-22 14:12:26 +08:00
You can config with [`ConfigProvider.config` ](/components/config-provider#configproviderconfig-4130 )