微信小程序之文件系统初探
微信小程序之文件系统初探
1、文件下载
//下载文件
go_download: function() {
var content = this;
var baseUrl = "http://rwh.blob.core.chinacloudapi.cn";
var fileName = "1-e2b214af930149ee80c8142d067148a7.exam";
var url = baseUrl + "/data/ExamBuilder2.0/20190320" + "/" + fileName;
console.log("dowload url:" + url);
//用户缓存目录
var userLocalPath = wx.env.USER_DATA_PATH;
var localPath = "wxfile://";
var path = userLocalPath + "/" + fileName
var localPath = localPath + "/" + fileName
var authorization = "Basic ZThlYWJmNWMwN2I0NGI0YmEzOGJmZWMyMTJkM2U1ZDU=";
var apptoken = "Authorization"
const downloadTask = wx.downloadFile({
// 待下载的云资源
url: url,
//下载成功后的回调函数
success(res) {
console.log("dowload res.errMsg:" + res.errMsg);
console.log("dowload res.statusCode:" + res.statusCode);
console.log("dowload res.tempFilePath:" + res.tempFilePath);
if (res.statusCode === 200) {
wx.showToast({
title: '下载成功!'
})
}
},
//失败回调函数
fai: function(res) {
console.log("downloadFile fai:" + res.errMsg)
},
//完成回调函数
complete: function() {
console.log("downloadFile complete")
content.getReaddir(targPath)
}
})
downloadTask.onProgressUpdate((res) => {
console.log('下载进度', res.progress)
console.log('已经下载的数据长度', res.totalBytesWritten)
console.log('预期需要下载的数据总长度', res.totalBytesExpectedToWrite)
})
// downloadTask.abort() // 取消下载任务
}
2、持久化文件到本地
//下载成功的文件目前存在temp文件夹下,它属于临时文件
//如果想要将其持久化,需要使用wx.saveFile()将其保存至store文件夹下,
//在使用这个函数时,temp文件夹下的临时文件会被删除。
wx.saveFile({
tempFilePath: res.tempFilePath,
success: function(res) {
console.log(res);
var savedFilePath = res.savedFilePath;
console.log('文件已下载到' + savedFilePath);
}
})
3、解压压缩文件
//解压文件
unzipFile: function(path, targPath) {
var content = this;
console.log("unzip path:" + path)
console.log("unzip targPath:" + targPath)
wx.getFileSystemManager().unzip({
//文件路径
zipFilePath: path,
//目标文件夹
targetPath: targPath,
//成功回调函数
success: function(res) {
console.log(res.errMsg)
},
//失败回调函数
fai: function(res) {
console.log("unzip fai:" + res.errMsg)
},
//完成回调函数
complete: function() {
console.log("unzip complete")
content.getReaddir(targPath)
}
});
}
3、读取文件到内存
//读取文件
readFile: function(path) {
console.log("readFile start path:" + path)
var userLocalPath = wx.env.USER_DATA_PATH;
wx.getFileSystemManager().readFile({
//文件路径
filePath: path,
//成功回调函数
success: function(res) {
console.log("unzip success res:" + res.errMsg)
console.log(res)
},
//失败回调函数
fai: function(res) {
console.log("unzip fai:" + res.errMsg)
},
//完成回调函数
complete: function() {
console.log("unzip complete")
}
});
}
4、查看目标文件夹的文件列表
// 查看下载的文件列表
getReaddir: function(path) {
console.log("getReaddir start")
wx.getFileSystemManager().readdir({
dirPath: path,
//成功回调函数
success: function(res) {
console.log("getReaddir success res:" + res.errMsg)
console.log(res)
},
//失败回调函数
fai: function(res) {
console.log("getReaddir fai:" + res.errMsg)
},
//完成回调函数
complete: function() {
console.log("getReaddir complete")
}
})
}
5、查看已经缓存的文件列表
// 查看下载的文件列表
getUserSavedFileList: function() {
console.log("getUserSavedFileList start")
wx.getFileSystemManager().getSavedFileList({
//成功回调函数
success: function(res) {
console.log("getUserSavedFileList success res:" + res)
console.log(res)
},
//失败回调函数
fai: function(res) {
console.log("getUserSavedFileList fai:" + res.errMsg)
},
//完成回调函数
complete: function() {
console.log("getUserSavedFileList complete")
}
})
}
微信小程序之文件系统初探的更多相关文章
- 微信小程序开发之初探
本文是以一个简单的小例子,来简要讲解微信小程序开发步骤,希望促进学习分享. 概念 微信小程序,简称小程序,缩写xcx,英文mini program.是一种不需要下载安装即可使用的应用,它实现了应用“触 ...
- 微信小程序初探--写个扫雷分享给你玩
闲暇里,想学一下微信小程序, 于是,用微信小程序原生做了个扫雷玩. 以下略作总结,分享给大家. 微信里下拉,输入[mini计算器], 看到这个图标的就是了: 说好的扫雷,怎么变成计算器了?原因后面解释 ...
- 微信小程序初探
做为码农相信大家最近肯定都会听到微信小程序,虽然现阶段还没有正式开放注册,但大家可以还是可以开发测试. 到微信的WIKI(http://mp.weixin.qq.com/wiki?t=resource ...
- 微信小程序开发初探
一.关于微信小程序 1.1 小程序诞生的背景 张小龙说道: (1)一切以用户价值为依归→用户是微信的核心,所以微信中没有很多与客户无关的功能,比如QQ中的乱七八糟一系列东西. (2)让创造发挥价值→所 ...
- 初探微信小程序
摘要 最近闲下来了,就准备了解下微信小程序的内容.首先从目录结构开始吧. 创建项目 工具下载:https://mp.weixin.qq.com/debug/wxadoc/dev/devtools/do ...
- weapp微信小程序初探demo
https://github.com/donglegend/weapp-demo 参考文档开发工具安装微信weapp API git项目源码微信小程序 demo效果展示效果预览
- 微信小程序初探【类微信UI聊天简单实现】
微信小程序最近很火,火到什么程度,只要你一打开微信,就是它的身影,几乎你用的各个APP都可以在微信中找到它的复制版,另外官方自带的跳一跳更是将它推到了空前至高的位置.对比公众号,就我的感觉来说,有以下 ...
- 微信小程序之初探(常见语法 VS vue)常见问题(点击不生效,数据绑定)
最近在调研微信小程序开发,对于一个前端小白来说,在各种框架都还用不熟的情况下,再来开发小程序确实还是不容易. 小程序出来之初,听过演讲,看过一点点儿视频,感觉和angular语法有点相似(PS:那是也 ...
- 微信小程序初探(二、分页数据请求)
大家好 波哥小猿又来啦[斜眼笑],昨天咱们讲了微信小程序简单数据请求,有没有照着教程实现请求的同学们啦 实现的同学举个爪[笑脸].哈哈,好了不扯犊子啦,我相信有的同学已经实现了简单的数据请求,没有实现 ...
随机推荐
- crontab 定时任务没有响应 检测步骤
设置规则 # 每分钟执行一次 */1 * * * * /scripts/script.sh # 每小时执行一次 0 */1 * * * /scripts/script.sh # 每天 02:00 执行 ...
- SpringCloud断路器(Hystrix)
一.为什么需要 Hystrix? 在微服务架构中,我们将业务拆分成一个个的服务,服务与服务之间可以相互调用(RPC).为了保证其高可用,单个服务又必须集群部署.由于网络原因或者自身的原因,服务并不能保 ...
- IPFS学习-分布式哈希表DHT
Distributed Hash Tables(DHT) 分布式哈希表是一个分布式的键值对存储结构.在IPFS网络中,每一个节点都维护一个DHT的子集.当节点接受到一个请求.该节点要么直接回复,要么通 ...
- asp.net MVC 在Controller控制器中实现验证码输出
asp.net mvc项目使用到验证码,为了让以前的WebForm代码能利用上代码经过稍微的改动即可使用代码如下: using System; using System.Collections.Gen ...
- Python-根据照片信息获取用户详细信息(微信发原图或泄露位置信息)
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者: 蒙娜丽胖 PS:如有需要Python学习资料的小伙伴可以加点击下方 ...
- 关于华为模拟器eNSP-防火墙USG6000V怎么重装镜像
一.首先关闭eNSP软件 二.打开Oracle VM VirtualBox 三.单击VirtualBox “管理 - 虚拟介质管理”,将vfw_usg.vdi下面的子链接释放然后删除 四.最后回到主界 ...
- POI解析Excel时,如何获取单元格样式以及单元格Style的一些操作
最近,公司运营平台需要上传Excel文件并进行解析导入数据库,在开发完成后出现了一个始料不及的生产bug,下面是具体原因: 1.在用POI解析Excel时,默认如果Excel单元格中没有数据,且单元格 ...
- Leetcode 之 Mysql(day01)
大四已经接近一半了,下学期就要准备找工作实习了.为了自己能找到一份比较满意的实习,今天开始要刷一下题目.今天就刷 MySQL 语言.以下就是我今天刷的题目.大家也可以去 leetcode 注册一个账号 ...
- linux用户身份与文件权限
用户 useradd [ 参数 ] 用户名 添加用户 sudo useradd -d /home/test -u 1001 -s /bin/bash name usermod [选项] 用户名 更改用 ...
- vue-cli3.0配置图片转base64的规则
vue-cli3.0发现打包的时候,一些小于10k的图片没有转base64,需要自己新建一个vue.config.js的文件(在根目录),然后进行如下配置,就可以控制图片转义规则 module.exp ...