::: anchor
:::

::: title 基本介绍
:::

::: describe 按钮用于开始一个即时操作。
:::

::: title 基础使用
:::

::: demo 使用 `lay-upload` 标签, 创建一个按钮上传单文件

<template>
  <lay-upload @done="getUploadFile" @choose="beginChoose">
    <template #preview>
      <div v-for="(item,index) in picList" :key="`demo1-pic-'${index}`">
        <img :src="item"/>
      </div>
    </template>
  </lay-upload>
</template>

<script>
import { ref,reactive } from 'vue'

export default {
  setup() {
    const picList = ref([]);
    const filetoDataURL=(file,fn)=>{
      const reader = new FileReader();
      reader.onloadend = function(e){
        fn(e.target.result);
      };
      reader.readAsDataURL(file);
    };
    const getUploadFile=(files)=>{
      if(Array.isArray(files)&&files.length>0){
        files.forEach((file,index,array)=>{
          filetoDataURL(file,(res)=>{
            console.log(res);
            picList.value.push(res);
            console.log(picList.value);
          });
        });
      }
    };
    const beginChoose =(e)=>{
      console.log("beginChoose",e);
    };
    return {
      getUploadFile,
      filetoDataURL,
      beginChoose,
      picList
    }
  }
}
</script>

:::

::: title 多文件上传
:::

::: demo 使用 `lay-upload` 标签, 并使用 `multiple` 创建一个可上传多个文件的上传组件

<template>
  <lay-upload :multiple="true"></lay-upload>
</template>

<script>
import { ref } from 'vue'

export default {
  setup() {
    return {
    }
  }
}
</script>

:::

::: title 拖拽上传
:::

::: demo 使用 `lay-upload` 标签, 使用 `drag属性` 创建一个可拖拽的上传文件域

<template>
  <lay-upload :drag="true"></lay-upload>
</template>

<script>
import { ref } from 'vue'

export default {
  setup() {

    return {
    }
  }
}
</script>

:::

::: title 自定义预览/上传禁用
:::

::: demo 使用 `lay-upload` 标签, 使用 `#preview` 自定义预览的UI交互,使用  `disabled` 添加上传禁用

<template>
  <lay-upload @done="getUploadFile2" :disabled="true">
    <template #preview>
      <div class="easy-wrap">
        <img src="https://chixian.oss-cn-hangzhou.aliyuncs.com/20211023003617_0706a.jpg" style="width:62.9px;height:63.2px"/>
        <img src="https://chixian.oss-cn-hangzhou.aliyuncs.com/20211023003617_0706a.jpg" style="width:62.9px;height:63.2px"/>
        <img src="https://chixian.oss-cn-hangzhou.aliyuncs.com/20211023003617_0706a.jpg" style="width:62.9px;height:63.2px"/>
        <img src="https://chixian.oss-cn-hangzhou.aliyuncs.com/20211023003617_0706a.jpg" style="width:62.9px;height:63.2px"/>
        <img src="https://chixian.oss-cn-hangzhou.aliyuncs.com/20211023003617_0706a.jpg" style="width:62.9px;height:63.2px"/>
      </div>
    </template>
  </lay-upload>
</template>

<script>
import { ref } from 'vue'
export default {
  setup() {
    const getUploadFile2 = (file)=>{
      console.log(file);
    };
    return {
      getUploadFile2
    }
  }
}
</script>

:::

::: title 提供默认剪裁功能

::: demo 使用 `lay-upload` 标签, 添加 `cut` 开启 选择文件后剪裁功能

<template>
  <lay-upload @cutdone="getCutDone" @cutcancel="getCutCancel" :cut="true" :multiple="false" @done="getFileDone">
    <template #preview>
      <div class="easy-wrap" v-if="cutUrl">
        <img :src="cutUrl"/>
      </div>
    </template>
  </lay-upload>
</template>

<script>
import { ref } from 'vue'
export default {
  setup() {
    const cutUrl = ref("");
    const getCutDone=(res)=>{
      console.log("getCutDone",res);
      cutUrl.value = res.msg;
    };
    const getCutCancel=(res)=>{
      console.log("getCutCancel",res);
    };
    const getFileDone=(res)=>{
      console.log("getFileDone",res);
    };
    return {
      getCutDone,
      getCutCancel,
      getFileDone,
      cutUrl
    }
  }
}
</script>

:::

::: title Upload 属性
:::

::: table

| 属性        | 描述     | 类型    | 默认值    | 可选值                             |
| ----------- | -------- | ------- | --------- | ---------------------------------- |
| url        | 服务端上传接口,返回的数据规范请详见下文     | string  | --        | -- |
| data      | 请求上传接口的额外参数   | object | --   | --                  |
| headers      | 接口的请求头     | object | -- | --                   |
| acceptMime    | 文件选择框时的可选文件类型 | string | `images`   | `images` |
| field    | 设定文件域的字段名     | string | `file`   | -- |
| size | 设置文件最大可允许上传的大小,单位 KB。不支持ie8/9 | number  | `0(不限制)`  | -- |
| multiple | 是否允许多文件上传。设置 true即可开启。不支持ie8/9 | boolean  | false  | -- |
| number | 设置同时可上传的文件数量,一般配合 multiple 参数出现。 | number  | `0(不限制)`  | -- |
| drag | 是否接受拖拽的文件上传,设置 false 可禁用。不支持ie8/9 | boolean  | true  | -- |
| disabled | 设置文件禁用 | boolean  | false  | -- |
| cut | 是否开启选择图片后检测,设置true可开启 | boolean  | false  | -- |
| cutOptions | 开启剪裁的模态弹窗与剪裁框的配置 | object  | { layerOption,copperOption }  | -- |

:::

::: title Upload 插槽
:::

::: table

| 名称    | 描述     | 参数 |
| ------- | -------- | ---- |
| preview | 自定义预览效果 | --   |

:::

::: title Upload 事件
:::

::: table

| 名称    | 描述     | 参数 |
| ------- | -------- | ---- |
| choose | 打开系统选择文件窗体的回调 | --   |
| before | 上传事务开启前的回调 | --   |
| done | 上传事务结束的回调 | --   |
| error | 上传事务中出现错误的回调 | --   |
| cutdown | 剪裁完成 | --   |
| cutclose | 剪裁取消 | --   |
:::


 

::: previousNext button