Uploader


上传组件。Uploader UI 提供与WeLink规范一致的视图。 组件提供了两种上传类型、多个上传状态、删除图片的样式。

  • 上传类型:单张图片上传、多张图片上传。
  • 上传状态:正在等待上传、上传中、上传成功、上传失败。

参数说明

Uploader

名称 类型 默认值 说明
files array [] 图片路径
lang object 超过最大图片是提示内容,例如{ maxError: maxCount => '最多只能上传6张图片' }
maxCount number 4 最大可选择多少图片
onChange func undefined 选择图片事件
onError func undefined 异常时事件
title string '图片上传' 标题

Uploader2

名称 类型 默认值 说明
display bool [] 只展示附件,无上传和删除文件功能
lang object 超过最大图片是提示内容,例如{ maxError: maxCount => '最多只能上传6张图片' }
maxCount number 4 最大可选择多少图片
files array [] 文件列表,包含 type 文件类型,如 pdf;name 文件名称;size 文件大小,如:1.1M;status 文件进度,如:60%
onError func 异常时事件
onChange func 选择图片事件
onFileClick func 点击查看文件信息事件
onDeleteClick func 点击删除文件事件
onUpload func 自定义上传事件,如果传了此方法,将覆盖默认上传图片的事件

效果示例

HTML
import React, { Component } from 'react';
import {
  Gallery, GalleryDelete, Uploader, Uploader2, CellsTitle 
} from '@wecode/react-weui';
import photoSrc from './photo.png';
import thumbSrc from './thumb.png';

class UploaderDemo extends Component {
  maxError = {
    maxError: maxCount => `Max ${maxCount} images allow`
  };

  constructor(props) {
    super(props);

    this.state = {
      gallery: false,
      demoFiles: [
        {
          url: thumbSrc
        },
        {
          url: photoSrc
        },
        {
          url: thumbSrc
        },
        {
          url: photoSrc,
          error: true
        },
        {
          url: thumbSrc,
          status: '50%'
        }
      ],
      demo2Files: [
        {
          type: 'pdf',
          name: '便携工作站1.pdf',
          size: '1.1M'
        },
        {
          type: 'ppt',
          name: '2016年华为全联接大会,现场照....ppt',
          size: '1.1M'
        }
      ],
      demo3Files: [
        {
          type: 'jpg',
          name: '便携工作站1.JPG',
          size: '1.1M',
          status: '100%'
        },
        {
          type: 'pdf',
          name: '2016年华为全联接大会,现场照....PDF',
          size: '1.1M',
          status: '60%'
        }
      ]
    };
  }

  getFileName(o) {
    const pos = o.lastIndexOf('/');
    return o.substring(pos + 1);
  }

  getFileSuffix(fileName) {
    const index1 = fileName.lastIndexOf('.');
    const index2 = fileName.length;
    const suffix = fileName.substring(index1 + 1, index2);
    return suffix;
  }

  renderGallery() {
    const { gallery, demoFiles } = this.state;
    if (!gallery) return false;

    const srcs = demoFiles.map(file => file.url);

    return (
      <Gallery
        src={srcs}
        show
        defaultIndex={gallery.id}
        onClick={e => {
          // avoid click background item
          e.preventDefault();
          e.stopPropagation();
          this.setState({ gallery: false });
        }}
      >
        <GalleryDelete
          onClick={(e, id) => {
            this.setState({
              demoFiles: demoFiles.filter((e, i) => i !== id),
              gallery: demoFiles.length <= 1
            });
          }}
        />
      </Gallery>
    );
  }

  render() {
    const { demoFiles, demo2Files, demo3Files } = this.state;
    return (
      <section>
        {this.renderGallery()}
        <CellsTitle>样例1</CellsTitle>
        <Uploader
          title="上传图片"
          maxCount={6}
          files={demoFiles}
          onError={msg => window.HWH5.toast({ msg, type: 'n' })}
          onChange={(file, e) => {
            const newFiles = [...demoFiles, { url: file.data }];
            this.setState({
              demoFiles: newFiles
            });
          }}
          onFileClick={(e, file, i) => {
            console.log('file click', file, i);
            this.setState({
              gallery: {
                url: file.url,
                id: i
              }
            });
          }}
          onDeleteClick={(e, file, i) => {
            this.setState({
              demoFiles: demoFiles.filter((event, idx) => idx !== i),
              gallery: false
            });
          }}
          lang={this.maxError}
        />
        <CellsTitle>样例2</CellsTitle>
        <Uploader2
          display
          title="附件"
          files={demo2Files}
          onFileClick={(e, file, i) => {
            console.log('file click', file, i);
          }}
        />
        <br />
        <Uploader2
          title="附件"
          maxCount={6}
          files={demo3Files}
          onError={msg => console.log(msg)}
          // onUpload={e => {
          //     console.log(123);
          // }}
          onChange={(file, e) => {
            const fileName = this.getFileName(file.data);
            const fileSuffix = this.getFileSuffix(fileName);
            const newFiles = [
              ...demo3Files,
              {
                url: file.data,
                type: fileSuffix,
                name: fileName,
                status: '0%'
              }
            ];
            const index = newFiles.length - 1;
            this.setState(
              {
                demo3Files: newFiles
              },
              () => {
                const filePath = file.data;
                console.log('调用上传接口', '---------', filePath, index);
                HWH5.uploadFile({
                  zip: false,
                  serverType: 0,
                  serverUrl:
                    'http://mcloud-uat.huawei.com/mcloud/mag/ProxyForText/imock/mock/upload',
                  filePath,
                  name: 'aufile',
                  timeout: 600000,
                  progress: 1,
                  formData: {
                    aufile: filePath,
                    name: 'aufile',
                    typesLimit: 'json,png',
                    sizeLimit: 100000
                  },
                  onProgress: _data => {
                    const { progress } = JSON.parse(_data);
                    const { demo3Files } = this.state;
                    const currentItem = { ...demo3Files[index] };
                    currentItem.status = progress + '%';
                    console.log(currentItem, '----demo3Files', progress);
                    demo3Files[index] = currentItem;
                    this.setState({
                      demo3Files
                    });
                  }
                })
                  .then(data => {
                    console.log('服务端返回数据:', data);
                  })
                  .catch(error => {
                    console.log('HWH5.uploadFile上传异常', error);
                  });
              }
            );
          }}
          onFileClick={(e, file, i) => {
            console.log('file click', file, i);
          }}
          onDeleteClick={(e, file, i) => {
            console.log(file, '--- file');
            this.setState({
              demo3Files: demo3Files.filter((event, idx) => idx !== i),
              gallery: false
            });
          }}
          lang={this.maxError}
        />
      </section>
    );
  }
}

export default UploaderDemo;

result. ""

    Not Found. ""