js+css实现手机端的多图片上传,为了方便使用,css和js都未内联,为性能建议使用时改为外联;
如要用到pc端,直接去掉px转换为rem的js代码,修改单位即可;
因multiple在安卓手机中不兼容,所以在安卓上只能一次选中一张图片,在iOS系统上可以实现多图片的上传;
一、预览图
data:image/s3,"s3://crabby-images/96d2e/96d2e34bde56701627f4fae0be2e790358146a98" alt="img_0971557380a75e6f40eef9ea75753b75.gif"
图片发自简书App
预览及下载地址:http://www.jq22.com/jquery-info11638
文件下载
项目中我们经常会遇到需要下载文件的功能,静态的文件资源可以使用 a 标签下载,动态的则需要我们通过 js 处理发送请求,然后将返回的url给a标签的url属性既可。
代码如下
data:image/s3,"s3://crabby-images/aa18c/aa18cc9bd57f314ac8cc08f30a0e47b579fc0bc8" alt="img_8bd144b27a9cc584f86756ba25228431.png"
二、文件上传
通过input 标签的 type=file来实现
data:image/s3,"s3://crabby-images/2dd2e/2dd2e9ec6621b6bc3ef28ff5463072bd8d334231" alt="img_f169b1444cbc3bbfa346763c004f29a5.png"
然后通过监听change事件获取到上传文件的信息,并通过此信息向后端发送请求,存储信息。
文件上传到云服务器
1、需要引入dingding-oss文件
data:image/s3,"s3://crabby-images/7521e/7521e0db3fbaf17f5e844d565a765b194206c37e" alt="img_bd30e4d25daccff5c5636ccc638c5e43.png"
2.在上传文件的组件中实例化OSS
data:image/s3,"s3://crabby-images/9dbc9/9dbc92fa56312f49541985e014af50e5eda74972" alt="img_98ba618f8c15d228b5862204b22bbdc1.png"
4.通过client.multipartUpload(生成的命名空间,获取到的图片对象)函数上传到云端(此案例是一次上传一张图片的案例,当上传多张图片的时候,函数的第二个参数为当前的图片信息即fileLIst[i]对象)
data:image/s3,"s3://crabby-images/02998/0299876790d17602864233fb6eeeef7047e44bfa" alt="img_19bcddc1592299f10e6ab8fb0176b093.png"
通过window.URL.createObjectURL(上传文件信息对象)生成url链接;可以在前端展示
三、vue多图片上传组件
先看效果
data:image/s3,"s3://crabby-images/403d9/403d9095c5676c4b39d4032297afc37913ef2627" alt="img_8f0601d981f645f7453aef3c5fb34355.png"
html实现:
data:image/s3,"s3://crabby-images/e6e2f/e6e2f24c996c5c21c53090f6cb795577882588d3" alt="img_85304469247fd6264db4b4ae51f2d737.png"
js实现
data:image/s3,"s3://crabby-images/97cf3/97cf35f7a8c4366fe44e35037f208556f032d775" alt="img_2e56c1f0cf65f92b1c29007ea07def2e.png"
data:image/s3,"s3://crabby-images/2844d/2844dbc95a052c6398c51c1658390d49a257b069" alt="img_c3fb4ea588ab237e7d1830f38bf30f90.png"
data:image/s3,"s3://crabby-images/f97cc/f97ccd8aad237ab2b094a3c18039b78bd407c793" alt="img_181fdfa1ae0e269a2bd8c06761173fe3.png"
data:image/s3,"s3://crabby-images/750e3/750e35d0ce6abf0bbd62e538a361706cb9872b1f" alt="img_67711e7366146093548dd90def64fa64.png"
css实现
data:image/s3,"s3://crabby-images/eb425/eb42515047bd9a25563c48967f172e624458fd61" alt="img_2d0ae1511868c5a09eac34da0dbe133d.png"
data:image/s3,"s3://crabby-images/a4f68/a4f68a69f2da8e6885dd950e2a21fa0fde3c4f4b" alt="img_8c327d8fb77c5b67e55926c262910f89.png"
data:image/s3,"s3://crabby-images/d4ec8/d4ec884dbea5e86945faec240659e9a5ee4c6b5b" alt="img_b3e79176ad186132e3c7db04e41f5559.png"
用上边的vue组件上传的图片,发送给服务端的是base64格式的图片,后端经过转码之后存储。
文件的git地址:https://github.com/wangAlisa/-vue