vue文件上传(单文件以及多文件)

使用vue就有很多UI组件,我用的是element。但是element和其他的组件都是图片单次上传,而且比较麻烦,样式和方法写起来都太乱了,基本上上传文件还是自己写的最舒服。文件分为单文件和多文件上传

1 单文件 

我用的是Element,所以我会借用element的样式和其他表单或者输入框统一。

这里是的上传input输入框,我用绝对定位将其放在后面的input 显示框的上面,后面的正常在文档流中,显示正常,又将绝对定位的上传框opacity设为0,这下只能显示后面的输入框,但点击输入框的时候上传框在因为绝对定位在其上面,所以会点击到上传框从而达到上传文件的效果

单文件表单

每次上传图片会触发上传框的change事件,我们获取到输入框的文件,然后获取其name,将其name赋值给filename,上面的输入框绑定了filename的值,所以会显示上传图片的文件名, 这样每次上传文件,文件名都会是新上传图片的名称。

js处理图片

有上传文件的接口一般是form表单的参数格式,等到提交表单的时候可以用 FormData对象去append各个参数就可以了。

2 多文件上传

多文件和上面文件思路差不多,但是有一点是不同的,既然多文件,可以连续删掉多个,一次添加多个,或者多次添加一个,这就不能讲文件名在输入框里显示了。


多文件表单

我们可以将上传框和单文件上传一样,设置绝对定位在上传按钮或者输入框的上面,上传框设置multiple属性,可一次上传多个,


批次添加文件

我们将文件名和文件调价到不通数组,文件名数组fileList在模板里用v-for遍历,每次上传都可以看到下面新增的文件名,参考多文件保单图,如有需要删除,我们将要将其图片在文件名数组中的index值传入删减函数,删除对应文件名,然后将其在文件数组中的同index文件删除,这样就可以实现不断加不断删的功能。不过,每次删除之前都要讲输入框的value值清空,这样删除之后还可以上传之前删除的文件。最后还是用FormData对象添加参数。

删除文件

结束了,这篇算是干货了吧。我看下能不能写成一个vue的插件来用

https://github.com/liulinqiang121/react-collection,欢迎使用和star

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明AGI阅读 16,003评论 3 119
  • 夜雨惊梦 梦里惊闪电,天公鼾声高。 急风扫沉闷,骤雨去暑燥。 夜半来匆匆,何必急归早? 如是复王命,玉帝太官僚!
    益德居士阅读 346评论 1 7
  • 你何苦像风一样刺骨 将我片刻的梦吹散 转眼心似光秃秃的树桠没着落的兀立
    绣花半朵阅读 368评论 0 2
  • c语言static 申明私有变量,函数外,文件外不可访问。 static变量是不会在栈中分配内存的,其内存在全局数...
    wangjianyu阅读 392评论 1 1
  • Cache一词来源于1967年的一篇电子工程期刊论文。其作者将法语词“cache”赋予“safekeeping s...
    Alex_1799阅读 309评论 0 0