微信小程序audio组件在ios端无法播放怎么解决
发表于:2025-11-09 作者:千家信息网编辑
千家信息网最后更新 2025年11月09日,今天小编给大家分享一下微信小程序audio组件在ios端无法播放怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有
千家信息网最后更新 2025年11月09日微信小程序audio组件在ios端无法播放怎么解决
今天小编给大家分享一下微信小程序audio组件在ios端无法播放怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
解决方法: 给 audio 组件绑定点击事件,手动触发播放暂停方法。
代码片段:
wxml文件
未找到通话录音
wxss文件
.reference { margin-top: 20rpx; height: 100%; padding: 5rpx; box-sizing: border-box;}.ref-btn { width: 80rpx; height: 80rpx; display: flex;}.ref-btn button { width: 80rpx; height: 80rpx; border-radius: 50%;}js文件
/** * 组件的初始数据 */ data: { currentGettingReferenceId: null, //正在播放的音频id audioResourceMaps: {}, //点击过的音频列表 isPause:false, // 是否暂停 },/** * 组件的生命周期 */ lifetimes: { attached: function () { // 因为是子组件 所以要在这里获取实例 this.audioContext = wx.createInnerAudioContext(); }, detached: function () { // 停止播放 this.stopAudio() // 在组件实例被从页面节点树移除时执行 }, }, methods: { // 获取录音 getReference(e) { let id = e.target.dataset.referenceId if(id != this.data.currentGettingReferenceId){ this.stopAudio() } this.setData({ currentGettingReferenceId:id }) // 点击获取录音url的接口。 接口请求根据自己的封装来写 WXAPI.getResourceUrl( `/conversation/conversationsession/${id}/`, { data_type: "all", }).then(({resource_url}) => { console.log("音频地址====",resource_url,) let url = resource_url && resource_url.indexOf("https://") > -1? encodeURI(resource_url) : null this.data.audioResourceMaps[id] = url; if(resource_url) this.playAudio(id,url) this.setData({ audioResourceMaps: this.data.audioResourceMaps }) console.log("播放过的列表=====",this.data.audioResourceMaps) }).catch(function (e) { console.log(e) }) }, // 暂停 pauseAudio(){ this.setData({ isPause: !this.data.isPause }) let id = this.data.currentGettingReferenceId console.log(id,"播放暂停的id") const innerAudioContext = this.audioContext if(this.data.isPause){ innerAudioContext.pause() console.log("暂停播放") }else{ innerAudioContext.play() console.log("继续播放") } }, // 停止播放 stopAudio(){ const innerAudioContext = this.audioContext innerAudioContext.stop() let obj = this.data.audioResourceMaps for(let item in obj){ delete obj[item] } // 停止播放就要把播放列表id对应的音频地址做清空处理 this.setData({ audioResourceMaps: obj, currentGettingReferenceId:null }) console.log("停止播放") }, // 播放 playAudio(id,url) { const innerAudioContext = this.audioContext console.log(url, "音频的地址") if(url){ innerAudioContext.src = url innerAudioContext.play() innerAudioContext.onPlay(() => { console.log("开始播放") }) innerAudioContext.onTimeUpdate(() => { console.log(innerAudioContext.duration,"总时长") console.log(innerAudioContext.currentTime,"当前播放进度") }) setTimeout(() => { console.log(innerAudioContext.duration,"总时长") console.log(innerAudioContext.currentTime,"当前播放进度") }, 500) innerAudioContext.onEnded(() => { let obj = this.data.audioResourceMaps for(let item in obj){ delete obj[item] } this.setData({ audioResourceMaps: obj, currentGettingReferenceId:null }) console.log("播放完毕") }) innerAudioContext.onError((res) => { console.log(res.errMsg) console.log(res.errCode) }) } }效果图
⚠️微信小程序中使用vant,必须要在.json 文件中引用 不然标签不会显示哦
我是在app.json文件引得 全局可用
"usingComponents": { "van-button": "@vant/weapp/button/index", "van-icon": "@vant/weapp/icon/index", }以上就是"微信小程序audio组件在ios端无法播放怎么解决"这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。
组件
文件
音频
知识
篇文章
程序
地址
内容
实例
接口
方法
时长
进度
不同
很大
事件
代码
全局
周期
大部分
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
梦幻西游黑龙江服务器云主机
淮安刀片服务器生产厂家
磁力播放数据库
东莞一橙网络技术做什么的
电子资源数据库属于服务类么
网络安全软件工程
网络安全知识班会图片
汤姆猫阵营的服务器
恒山系列鲲鹏服务器采购
猪兼强互联网科技有限公司
鼎诚网络安全专业
关系数据库的逻辑模型是
高性能服务器框架
天龙手游服务器
打鱼游戏软件开发公司
美国防部网络技术
软件开发管理平台用户手册
软件开发技术主管工作内容
软件开发运维流程
美国微软软件开发工资
oracle数据库最大值
定西计算机网络技术
索尼游戏都用什么软件开发的
java删除数据库
网络技术方向职业
北邮网研网络安全中心
未来之役选择哪个服务器人多
几百万的服务器
dl388服务器什么品牌
计算机网络技术学3d建模吗