温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

微信小程序怎么实现自动保存下载文件名

发布时间:2022-01-13 15:34:37 来源:亿速云 阅读:350 作者:iii 栏目:大数据

本篇内容介绍了“微信小程序怎么实现自动保存下载文件名”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

问题的提出

小程序使用wx.playVoice播放音频时,需要从网上下载播放的对象文件,但是每次播放都要下载的话,就太傻了。好在小程序提供了保存文件的功能。

思路

准备一个url到缓存文件的映射,当小程序成功的下载播放铃声以后,自动保存下载的文件名。下次播放同一个文件时确认是否存在已经下载的文件,如果有则直接播放已经下载的文件。由于某些不知道的原因,我们假设已经下载的文件也可能播放失败,对策是重新下载该文件。

实现

下面的代码在app.js中,是这个处理的主线。

//播放铃声文件,优先使用缓存文件,根据需要下载。

 playRingtone: function(index) {

   var that = this

   var url = that.getRingtoneUrl(index)

   var savedFile = that.globalData.urlMap[url]

   if (savedFile != undefined){      

     //已经存在缓存文件,直接播放缓存文件

     that.addLog('播放缓存铃声')

     wx.playVoice({

       filePath: savedFile,

       fail:function(){

         //播放缓存文件失败,清除缓存文件信息

         that.globalData.urlMap[url] = undefined;

         wx.setStorageSync('urlMap', that.globalData.urlMap);

         //下载并播放缓存文件

         that.downloadAndPlayRingtone(url)

       },

     })

   }else{

     //没有缓存文件,下载并播放

     that.downloadAndPlayRingtone(url)

   }

 },

程序中用到了downloadAndPlayRingtone函数,其代码如下。

 //下载,保存,播放铃声文件。

 downloadAndPlayRingtone:function(url){

   var that = this

   that.downloadFile({

     url: url,

     success: function (savedFilePath) {

       //that.addLog('saveFileSuccess')

       //下载成功,播放文件

       that.addLog('播放下载铃声')

       wx.playVoice({

         filePath: savedFilePath,

       })

       //更新缓存文件信息。

       that.globalData.urlMap[url] = savedFilePath;

       wx.setStorageSync('urlMap', that.globalData.urlMap);

     }

   })

 },

下载铃声和播放铃声是应用领域的功能,为了促进代码重用,我们又抽出一个共同函数downloadFile。

提炼共通功能的关键并不在于它会被多少次使用,而在于它可以成为一个共通的功能。

//下载并保存文件

 downloadFile: function(parameter){

   var that = this

   wx.downloadFile({

     url: parameter.url,

     success: function (res) {

       //保存临时文件,以供将来使用

       wx.saveFile({

         tempFilePath: res.tempFilePath,

         success: function (save_res) {

           parameter.success(save_res.savedFilePath)

         }

       })

     },

   })  

 },

执行结果

可以看到,第一次是播放下载铃声,以后都是播放缓存铃声。log的出处可从代码中找到。

微信小程序怎么实现自动保存下载文件名

“微信小程序怎么实现自动保存下载文件名”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI