# l-file
### 完整示例可导入示例项目运行
不要期待更新,我很懒~
希望能帮到你!
附件选择上传已单独发布插件,使上传按钮完全内嵌于页面,不再从底部单独二次弹框
若只需要用文件选择上传功能,建议使用新版组件:
[全文件选择上传2.0版](https://ext.dcloud.net.cn/plugin?id=5459)
本插件也可以继续使用,根据需求选择
---
## 使用说明
| 属性| 是否必填| 值类型| 返回值| 说明|
| --------- | -------- | -----: | --: | --: |
| @up-success|否 | CallBack|{data,name,size} | 上传成功回调data为服务端返回值|
## ref调用
|作用 | 方法| 传入参数类型| 说明|
|---- | --------- | -------- | --: |
|下载| download|<URL,type,fileName>| type='save'为保存到本地,默认为获取临时路径|
|预览| open|URL| 预览文件|
|上传| upload|Object| 上传文件,参数见下方函数说明|
### vue:
``` javascript
// 以下代码写于根目录下第一个view顶部或跟在自定义导航栏后面
<l-file
ref="lFile"
@up-success="upSuccess"
></l-file>
```
---
* 函数说明
``` javascript
/* 临时下载文件并打开查看 */
this.$refs.lFile.download({url})
.then(path=>{
// 打开文件
this.$refs.lFile.open(path);
});
/**
* =======附件下载=======
*
* type 非save为临时下载
* customName 仅type=save生效 附件自定义名称需带后缀,自定义目录需以/结尾
* DownloadOptions 仅type=save生效 可选参数(http://www.html5plus.org/doc/zh_cn/downloader.html#plus.downloader.DownloadOptions)
* 默认下载到_downloads/files/ 可通过DownloadOptions自定义
*/
this.$refs.lFile.download({
url, //必填,附件网络地址
type:'save', //选填,非save为临时下载
customName:'自定义文件名需要带后缀.jpg',
//...DownloadOptions直接写key:value
// 例如:
method: 'GET'
})
.then(path=>{
this.localPath = path;
});
/*
=======选择文件+上传=======
url=上传服务器地址,必填
name=上传文件的key(选填,默认为file)
header=请求头(选填)
*/
this.$refs.lFile.upload({
//替换为你的上传接口地址
url: 'http://document/upload',
// 服务端接收附件的key
name: 'file',
//根据你接口需求自定义 (优先不传content-type,安卓端无法收到参数再传)
header: {
'Authorization': 'bearer eyJhbGciO',
'uid': '27682',
'client': 'app',
},
// 限制选择附件的大小上限,默认10M
// maxSize: 20,
// 若需要在body单独添加附件名或附件大小如下方式传入组件:
// addName: '后端要的附件名称字段key,此处请勿写name的同值如(file),会覆盖name',
// addSize: '后端要的附件大小字段key'
// body参数直接写key,value,如:
// date: '2020-1-1',
// key2: 'value2',
});
```
## 温馨提示
* 文件上传
0. 如不清楚怎么调用可导入完整示例可查看使用方式
1. APP端请优先联调Android,上传成功后再运行iOS端,如iOS返回status=0则需要后端开启允许跨域;
2. header的Content-Type类型需要与服务端要求一致,否则收不到附件(服务端若没有明文规定则可不写,使用默认匹配)
3. java不清楚怎么配置跨域可以找我;若是php,跨域需要注意不能配置为*星号,需为file单独设置跨域,具体百度~
4. 欢迎加入QQ讨论群1:701468256(已满)
5. 欢迎加入QQ讨论群2:469580165
LeeBrook0
- 粉丝: 45
- 资源: 25
最新资源
- 基于强化学习的自动化神经网络架构设计AutoDL源码
- 基于C语言的多媒体框架chromium_third_party_ffmpeg设计源码
- COMSOL注浆 考虑裂隙倾角(可更改倾角度数),在注浆压力条件下或者注浆速率条件下,扩散距离情况和压力分布情况 可指定是注浆
- 基于博途1200PLC+HMI3x3立体车库~手动版~控制系统仿真 程序: 1、任务:PLC.人机界面横移式升降立体车库运行仿真
- 基于RabbitMQ的Java分布式事务设计源码解析
- 直接序列扩频Matlab仿真和FPGA实现
- 基于Python的频域空域双分支视频和谐化V4设计源码
- 基于COSTAS 环的残余频偏偏差补偿MATLAB仿真和FPGA实现
- 基于Java与多语言集成的bistoury设计源码探索
- 燃料电池电池超级电容复合能量管理策略simulink仿真模型,advisor仿真 燃料电池 电池 超级电容复合能量管理策略 1、
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈