mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-16 01:29:11 +08:00
6776bb8916
* docs: update demo * chore: add script * test: fix demo test * docs: convert demos * chore: move script * test: remove react-dom import * chore: update deps * docs: update riddle js * test: fix image test * docs: fix riddle demo
43 lines
1.2 KiB
Markdown
43 lines
1.2 KiB
Markdown
---
|
|
order: 7.1
|
|
title:
|
|
zh-CN: 只上传 png 图片
|
|
en-US: Upload png file only
|
|
---
|
|
|
|
## zh-CN
|
|
|
|
`beforeUpload` 返回 `false` 或 `Promise.reject` 时,只用于拦截上传行为,不会阻止文件进入上传列表([原因](https://github.com/ant-design/ant-design/issues/15561#issuecomment-475108235))。如果需要阻止列表展现,可以通过返回 `Upload.LIST_IGNORE` 实现。
|
|
|
|
## en-US
|
|
|
|
`beforeUpload` only prevent upload behavior when return false or reject promise, the prevented file would still show in file list. Here is the example you can keep prevented files out of list by return `UPLOAD.LIST_IGNORE`.
|
|
|
|
```jsx
|
|
import React, { useState } from 'react';
|
|
import { Upload, Button, message } from 'antd';
|
|
import { UploadOutlined } from '@ant-design/icons';
|
|
|
|
const Uploader = () => {
|
|
const props = {
|
|
beforeUpload: file => {
|
|
const isPNG = file.type === 'image/png';
|
|
if (!isPNG) {
|
|
message.error(`${file.name} is not a png file`);
|
|
}
|
|
return isPNG || Upload.LIST_IGNORE;
|
|
},
|
|
onChange: info => {
|
|
console.log(info.fileList);
|
|
},
|
|
};
|
|
return (
|
|
<Upload {...props}>
|
|
<Button icon={<UploadOutlined />}>Upload png only</Button>
|
|
</Upload>
|
|
);
|
|
};
|
|
|
|
export default () => <Uploader />;
|
|
```
|