700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > vue文件上传(单文件以及多文件)

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

时间:2024-08-29 13:44:02

相关推荐

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对象添加参数。

删除文件

结束了,地址:/fgXtRtnu

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。