WebView中file标签不能上传文件
本文主要是从以下几点对这个问题进行了阐释:
- 简述
- 如何在Andorid设置中用webview来识别file标签的呢
- 实例代码
简述
Android WebView在Android平台上是一个特殊的View, 他能用来显示网页,这个类可以被用来在你的app中仅仅显示一张在线的网页,还可以用来开发浏览器。WebView内部实现是采用渲染引擎来展示view的内容,提供网页前进后退,网页放大,缩小,搜索,前端开发者可以使用web inspector(Android 4.4系统支持,4.4一下可以采用http://developer.android.com/guide/webapps/debugging.html)调试HTML,CSS,JavaScript等等功能。在Android 4.3系统及其一下WebView内部采用Webkit渲染引擎,在Android 4.4采用chromium 渲染引擎来渲染View的内容。
WebView的好处:
1.用它加载网页数据
2.Html与java交互
3.等等(扯淡了。。。)
WebView识别file标签
为什么WebView不能直接识别file标签呢?
在webview中加载web网页,当设计到用户处罚的web点击事件,都需要去调用响应的事件处理js来处理。在pc上,js是可以直接调用window的,因为浏览器具有window的所有权,所以可以直接访问,而在移动端,js对window窗体是不具有控制权的,所以就需要有一个调用接口,来触发。那么?到底有没有这个调用交互接口呢?我查阅了网上的资料发现,webview的setWebChromeClient这个属性可以在webview 和 js之间行成对接,通过WebChromeClient接口可以监听js处理的事件过程,因此,我们只需要在这个里面找答案即可。
怎么去使用WebChromeClient的监听点击的file事件呢?
webView的setWebChromeClient的这个方法需要传入一个WebChromeClient对象,查阅发现WebChromeClient这个对象有几个和文件上传有关的监听方法,如下表所示:
方法名 | 描述 |
---|---|
openFileChooser | 在Android5.0之前对文件处理的方法 |
onShowFileChooser | 在Android5.0之后对文件处理的方法 |
详细信息请看下方代码:
//扩展浏览器上传文件
//3.0++版本
public void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType) {
openFileChooserImpl(uploadMsg);