微信小程序之文件系统初探

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")
}
})
}

微信小程序之文件系统初探的更多相关文章

  1. 微信小程序开发之初探

    本文是以一个简单的小例子,来简要讲解微信小程序开发步骤,希望促进学习分享. 概念 微信小程序,简称小程序,缩写xcx,英文mini program.是一种不需要下载安装即可使用的应用,它实现了应用“触 ...

  2. 微信小程序初探--写个扫雷分享给你玩

    闲暇里,想学一下微信小程序, 于是,用微信小程序原生做了个扫雷玩. 以下略作总结,分享给大家. 微信里下拉,输入[mini计算器], 看到这个图标的就是了: 说好的扫雷,怎么变成计算器了?原因后面解释 ...

  3. 微信小程序初探

    做为码农相信大家最近肯定都会听到微信小程序,虽然现阶段还没有正式开放注册,但大家可以还是可以开发测试. 到微信的WIKI(http://mp.weixin.qq.com/wiki?t=resource ...

  4. 微信小程序开发初探

    一.关于微信小程序 1.1 小程序诞生的背景 张小龙说道: (1)一切以用户价值为依归→用户是微信的核心,所以微信中没有很多与客户无关的功能,比如QQ中的乱七八糟一系列东西. (2)让创造发挥价值→所 ...

  5. 初探微信小程序

    摘要 最近闲下来了,就准备了解下微信小程序的内容.首先从目录结构开始吧. 创建项目 工具下载:https://mp.weixin.qq.com/debug/wxadoc/dev/devtools/do ...

  6. weapp微信小程序初探demo

    https://github.com/donglegend/weapp-demo 参考文档开发工具安装微信weapp API git项目源码微信小程序 demo效果展示效果预览

  7. 微信小程序初探【类微信UI聊天简单实现】

    微信小程序最近很火,火到什么程度,只要你一打开微信,就是它的身影,几乎你用的各个APP都可以在微信中找到它的复制版,另外官方自带的跳一跳更是将它推到了空前至高的位置.对比公众号,就我的感觉来说,有以下 ...

  8. 微信小程序之初探(常见语法 VS vue)常见问题(点击不生效,数据绑定)

    最近在调研微信小程序开发,对于一个前端小白来说,在各种框架都还用不熟的情况下,再来开发小程序确实还是不容易. 小程序出来之初,听过演讲,看过一点点儿视频,感觉和angular语法有点相似(PS:那是也 ...

  9. 微信小程序初探(二、分页数据请求)

    大家好 波哥小猿又来啦[斜眼笑],昨天咱们讲了微信小程序简单数据请求,有没有照着教程实现请求的同学们啦 实现的同学举个爪[笑脸].哈哈,好了不扯犊子啦,我相信有的同学已经实现了简单的数据请求,没有实现 ...

随机推荐

  1. 使用react-app-rewired和customize-cra对默认webpack自定义配置

    最近在学习react框架,之前一直都是用vue 开发,知道在vue 中知道如何配置一下相关的webpack 有助于开发,学react 过程中,我也在想这些该怎么配置啊,所以就有这篇文章. 这篇文章主要 ...

  2. GetPrivateProfileString() 当 key 包含空格时,需要进行转义

    使用 GetPrivateProfileString() 方法可以方便的读取 ini 格式文件中的内容,如: [section] tommy = worker 使用 C# 读取如下: 1. 先引入 G ...

  3. 如何把Mybatis的Mapper.xml配置文件和dao接口放在同一个包下

    有的时候我们在Maven项目中写关于Mybatis的项目时,会涉及到很多的实体类,也就会涉及到很多的dao接口,如果此时我们仍然把dao接口和xml写在同一个包下,会让项目接口变得很乱,杂七杂八的,所 ...

  4. 阿里巴巴供应链平台事业部2020届秋招-Java工程师

    阿里巴巴供应链平台事业部,2020届秋季校园招聘开始啦!Java开发工程师虚位以待,机会难得,占坑抓紧. 入职就发师兄,一对一师兄辅导. 在这里,你将有机会接触阿里集团的所有数据库.中间件等基础设施. ...

  5. Redis学习二(数据操作).

    key 操作 删除 key:del key 批量删除key:redis-cli -a(密码)keys "QXJ_*"| xargs redis-cli -a(密码)del 查看所有 ...

  6. sap-abap 权限控制

    FORM AUTH_CHECK . "工厂 LOOP AT S_WERKS. AUTHORITY-CHECK OBJECT 'M_BANF_WRK' ID 'WERKS' FIELD S_W ...

  7. C# List 根据对象属性去重的四种方法对比

    测试代码: private void TestDistinct() { Task.Run(() => { //生成测试数据 DateTime dt = DateTime.Now; Random ...

  8. 前端最佳实践——DOM操作

    1.浏览器渲染原理 在讲DOM操作的最佳性能实践之前,先介绍下浏览器的基本渲染原理. 分为以下四个步骤: 解析HTML(HTML Parser) 构建DOM树(DOM Tree) 渲染树构建(Rend ...

  9. leaflet-webpack 入门开发系列五地图卷帘(附源码下载)

    前言 leaflet-webpack 入门开发系列环境知识点了解: node 安装包下载webpack 打包管理工具需要依赖 node 环境,所以 node 安装包必须安装,上面链接是官网下载地址 w ...

  10. TICK技术栈(五)Kapacitor安装及使用

    1.什么是Kapacitor? Kapacitor是InfluxData开源的数据处理引擎.它可以处理来自InfluxDB的流数据和批处理数据,并且用户可以用tickScript脚本来处理,监视和警报 ...