cordova/ionic制做一个文件浏览器(一)

开始学习ionic有一段时间了,问遍谷哥和度娘,都没有找到一个方便好用的文件浏览器,因此决定本身写一个文件浏览器。动工以前,先找参考资料,通过筛选,有两个资料具备参考意义
github上的一个写好的示例:ionic编写的
极客学院的教程(参考html file api的教程):cordova编写的html

根据github上的例子,一步一步写完之后,悲剧的事情发生了,打开文件浏览器一片空白;后来又专门打开视频看了一遍操做演示,反复对比没有遗漏的地方,可是浏览器打开仍是一片空白。接着看极客学院的视频教程,按照操做步骤一步一步作了之后,打开浏览器依然是一片空白。下载了教程中提供的资料,里面有一个apk包,安装之后,神奇的事情发生了,文件浏览器正常显示了。此刻我陷入了沉思。。。android

为了排除个别设备的影响,在另一台设备上从新进行了测试,文件浏览器依然是一片空白。既然SD卡根目录没法读取,那就试一下其余目录吧,结果却让人大跌眼镜,除了SD卡根目录,其余目录均可以正常读取。忽然的灵感迸发,会不会是因为android的版本影响呢,我就用同事android5.1版本(以前测试的都是android6.0)的手机进行了测试,结果让人喜出望外,文件浏览器能够正常显示了。git

既然定位到了问题,那就想办法解决了,原来是因为android6.0权限控制方面进行了升级,对权限的请求进行了分组,请求读写外部存储设备是“危险”类的请求,须要在运行时进行请求。详细说明可参考官方说明 中文说明github

针对这个问题,目前我想到了两个解决办法:
1.修改android的编译版本
2.添加运行时请求权限的功能apache

本节就最简单的第一种方法进行说明
AndroidManifest.xml中修改以下配置android:targetSdkVersion 23(默认值和安装的cordova版本有关,我这里安装的是6.0版本)改成22
<uses-sdk android:minSdkVersion="16" android:targetSdkVersion="22" />api

未完待续。。。浏览器


运行效果图:
图片描述app


参考内容:
一样是6.0没法建立文件,启发了第一种解决思路
启发了第二种解决思路
请求权限插件
请求权限插件调用示例ionic

相关文章
相关标签/搜索