237 lines
5.8 KiB
Markdown
237 lines
5.8 KiB
Markdown
::: 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
|