拍照上传器
‘壹’ 百度怎么拍照片上传
1.首先打开一个浏览器,输入网络一下进行搜索,然后在打开的网络页面中点击“网络一下”前面红色框内的“拍照”图标。
2. 在打开的图片上传界面,你可以点击红框内的“本地上传图片”按钮,上传你自己的图片;也可以将你的图片直接拖拽在有十字的“拖拽图片到这里”,进行上传。
3. 在点击“本地上传图片”按钮后,你可以在你电脑中找到你要上传的图片,选择好,点击下面的“打开”,等待加载完成即可成功上传。
注意:可以先拍好照片,然后更方便上传。
‘贰’ 图片拍照上传解决方案
微信内置浏览器,和一些主流浏览器支持调用摄像头,但也有很多不支持调用摄像头,仅支持相册。
如果是WebView中,就需要客户端支持了,android和ios的权限也是问题。
formData 简介
简单的说就是:通过formData,我们可以用ajax方式来发送表单数据;以前上传图片是需要用form表单提交的。
我们知道浏览器默认显示的文件上传按钮是很丑的,通常UI都会对上传按钮进行设计。有以下几种方案来写样式。
弊端:
坑
通过ref获取上传按钮。
ref方式
event.target方式
坑:
FileReader 简介
通过 readAsDataURL() ,在读取操作完成后,result属性中将包含一个data:URL格式的字符串以表示所读取文件的内容。
base64字符串
兼容性
我在safari中测试,发现是支持的。
URL.createObjectURL 简介
通过URL.createObjectURL()创建一个URL对象,这个URL对象表示指定的file对象或Blob对象。
兼容性
张鑫旭的文章: HTML5 file API加canvas实现图片前端JS压缩并上传
张鑫旭的文章: 理解DOMString、Document、FormData、Blob、File、ArrayBuffer数据类型
使用Camera API
张鑫旭