audio的音频路径写死时没有问题
<audio id="audio" autoplay>
    <source src="../aa.mp3" type="audio/mpeg"/>
</audio>
当路径是从后台获取,动态加上的时候,播放的时候获取不到duration
<audio id="audio" autoplay>
    <source :src="infoData.audios_src" type="audio/mpeg" />
</audio>
解决方法:在获取数据的时候,加一个判断,让它load()一下就可以了
getLessonInfo:function(){
    var self = this;
    axios.get(baseURL,{
        params:{
            api_token:self.api_token,
            member_id:self.member_id,
            course_id:self.course_id
        }
    }).then(function(res){
        var _tagArr = [];
        var audio = document.getElementById("audio");
        self.infoData = res.data.data;
        var audio_src = res.data.data.audios_src;
        if(audio_src){
                        //load()方法重新加载音频/视频元素
                    audio.load();
        }
    });
}
                
                  
                  
                  
                  
                            
本文介绍了一个关于HTML5音频播放器中duration属性在动态加载音频文件时无法正常更新的问题及其解决方案。通过在加载音频文件后调用load()方法,可以确保duration属性正确显示。
          
      
          
                
                
                
                
              
                
                
                
                
                
              
                
                
              
            
                  
					9964
					
被折叠的  条评论
		 为什么被折叠?
		 
		 
		
    
  
    
  
            


            