2016-08-17 11:07:02 +08:00
---
category: Components
2016-11-09 14:43:32 +08:00
type: Feedback
2016-08-17 11:07:02 +08:00
noinstant: true
2016-09-09 13:55:46 +08:00
title: Notification
2016-08-17 11:07:02 +08:00
---
2017-09-11 11:08:34 +08:00
Display a notification message globally.
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.
## API
- `notification.success(config)`
- `notification.error(config)`
- `notification.info(config)`
- `notification.warning(config)`
- `notification.warn(config)`
2018-07-18 14:55:47 +08:00
- `notification.open(config)`
2016-08-17 11:07:02 +08:00
- `notification.close(key: String)`
- `notification.destroy()`
The properties of config are as follows:
2019-11-20 17:46:50 +08:00
| Property | Description | Type | Default |
| --- | --- | --- | --- |
| bottom | Distance from the bottom of the viewport, when `placement` is `bottomRight` or `bottomLeft` (unit: pixels). | number | 24 |
| btn | Customized close button | ReactNode | - |
| className | Customized CSS class | string | - |
| description | The content of notification box (required) | string\|ReactNode | - |
| duration | Time in seconds before Notification is closed. When set to 0 or null, it will never be closed automatically | number | 4.5 |
| getContainer | Return the mount node for Notification | () => HTMLNode | () => document.body |
| icon | Customized icon | ReactNode | - |
2019-12-01 21:46:17 +08:00
| closeIcon | custom close icon | ReactNode | - |
2019-11-20 17:46:50 +08:00
| key | The unique identifier of the Notification | string | - |
| message | The title of notification box (required) | string\|ReactNode | - |
| onClose | Specify a function that will be called when the close button is clicked | Function | - |
| onClick | Specify a function that will be called when the notification is clicked | Function | - |
| placement | Position of Notification, can be one of `topLeft` `topRight` `bottomLeft` `bottomRight` | string | `topRight` |
| style | Customized inline style | [React.CSSProperties ](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/e434515761b36830c3e58a970abf5186f005adac/types/react/index.d.ts#L794 ) | - |
| top | Distance from the top of the viewport, when `placement` is `topRight` or `topLeft` (unit: pixels). | number | 24 |
2016-08-17 11:07:02 +08:00
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
- `notification.config(options)`
2017-10-25 10:25: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,
});
```
2019-11-20 17:46:50 +08:00
| Property | Description | Type | Default |
| --- | --- | --- | --- |
| bottom | Distance from the bottom of the viewport, when `placement` is `bottomRight` or `bottomLeft` (unit: pixels). | number | 24 |
2019-12-01 21:46:17 +08:00
| closeIcon | custom close icon | ReactNode | - |
2019-11-20 17:46:50 +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 |
| getContainer | Return the mount node for Notification | () => HTMLNode | () => document.body |
| placement | Position of Notification, can be one of `topLeft` `topRight` `bottomLeft` `bottomRight` | string | `topRight` |
| top | Distance from the top of the viewport, when `placement` is `topRight` or `topLeft` (unit: pixels). | number | 24 |
2020-02-07 17:55:27 +08:00
## FAQ
### What's different between hooks and directly call?
antd will dynamic create React instance by `ReactDOM.render` when directly call notification methods. Whose context is different with origin code located context.
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" >
{contextHolder}
< Context2.Provider value = "Design" >
{/* contextHolder is out of Context2 which mean api will not get context of Context2 */}
< / 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.