mirror of
https://gitee.com/ant-design/ant-design.git
synced 2024-12-15 09:21:22 +08:00
9f98fc243e
* feat(App): add message & notification options * chore: test * docs: App docs * feat: config inherit in nest app * feat: provide & consume config context internally * docs(App): property literal * fix(App): repect config from props in priority * Update components/app/index.en-US.md * Update components/app/index.zh-CN.md --------- Co-authored-by: MadCcc <1075746765@qq.com>
129 lines
3.1 KiB
Markdown
129 lines
3.1 KiB
Markdown
---
|
|
category: Components
|
|
group: Other
|
|
title: App
|
|
cover: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*HJz8SZos2wgAAAAAAAAAAAAADrJ8AQ/original
|
|
coverDark: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*oC92TK44Ex8AAAAAAAAAAAAADrJ8AQ/original
|
|
demo:
|
|
cols: 2
|
|
---
|
|
|
|
New App Component which provide global style & static function replacement.
|
|
|
|
## When To Use
|
|
|
|
Static function in React 18 concurrent mode will not well support. In v5, we recommend to use hooks for the static replacement. But it will make user manual work on define this.
|
|
|
|
## Examples
|
|
|
|
<!-- prettier-ignore -->
|
|
<code src="./demo/basic.tsx">basic</code>
|
|
|
|
## How to use
|
|
|
|
### Basic usage
|
|
|
|
App provides upstream and downstream method calls through `Context`, because useApp needs to be used as a subcomponent, we recommend encapsulating App at the top level in the application.
|
|
|
|
```tsx
|
|
import { App } from 'antd';
|
|
import React from 'react';
|
|
|
|
const MyPage: React.FC = () => {
|
|
const { message, notification, modal } = App.useApp();
|
|
message.success('Good!');
|
|
notification.info({ message: 'Good' });
|
|
modal.warning({ title: 'Good' });
|
|
// ....
|
|
// other message, notification, modal static function
|
|
return <div>Hello word</div>;
|
|
};
|
|
|
|
const MyApp: React.FC = () => (
|
|
<App>
|
|
<MyPage />
|
|
</App>
|
|
);
|
|
|
|
export default MyApp;
|
|
```
|
|
|
|
Note: App.useApp must be available under App.
|
|
|
|
### Sequence with ConfigProvider
|
|
|
|
The App component can only use the token in the `ConfigProvider`, if you need to use the Token, the ConfigProvider and the App component must appear in pairs.
|
|
|
|
```tsx
|
|
<ConfigProvider theme={{ ... }}>
|
|
<App>
|
|
...
|
|
</App>
|
|
</ConfigProvider>
|
|
```
|
|
|
|
### Embedded usage scenarios (if not necessary, try not to do nesting)
|
|
|
|
```tsx
|
|
<App>
|
|
<Space>
|
|
...
|
|
<App>...</App>
|
|
</Space>
|
|
</App>
|
|
```
|
|
|
|
### Global scene (redux scene)
|
|
|
|
```tsx
|
|
// Entry component
|
|
import { App } from 'antd';
|
|
import type { MessageInstance } from 'antd/es/message/interface';
|
|
import type { ModalStaticFunctions } from 'antd/es/modal/confirm';
|
|
import type { NotificationInstance } from 'antd/es/notification/interface';
|
|
|
|
let message: MessageInstance;
|
|
let notification: NotificationInstance;
|
|
let modal: Omit<ModalStaticFunctions, 'warn'>;
|
|
|
|
export default () => {
|
|
const staticFunction = App.useApp();
|
|
message = staticFunction.message;
|
|
modal = staticFunction.modal;
|
|
notification = staticFunction.notification;
|
|
return null;
|
|
};
|
|
|
|
export { message, notification, modal };
|
|
```
|
|
|
|
```tsx
|
|
// sub page
|
|
import { Button, Space } from 'antd';
|
|
import React from 'react';
|
|
import { message } from './store';
|
|
|
|
export default () => {
|
|
const showMessage = () => {
|
|
message.success('Success!');
|
|
};
|
|
|
|
return (
|
|
<Space>
|
|
<Button type="primary" onClick={showMessage}>
|
|
Open message
|
|
</Button>
|
|
</Space>
|
|
);
|
|
};
|
|
```
|
|
|
|
## API
|
|
|
|
### App
|
|
|
|
| Property | Description | Type | Default | Version |
|
|
| --- | --- | --- | --- | --- |
|
|
| message | Global config for Message | [MessageConfig](/components/message/#messageconfig) | - | 5.3.0 |
|
|
| notification | Global config for Notification | [NotificationConfig](/components/notification/#notificationconfig) | - | 5.3.0 |
|