如果未找到动态音频src或为null,则使用javascript隐藏HTML5音频播放器

时间:2013-11-04 22:08:17

标签: javascript jquery html5 jquery-mobile audio

Stackoverflow上的第一篇帖子请跟我说。 我有一个JQMobile Web应用程序,它通过JSON生成动态音频文件链接,并为每个id附加音频播放器。我试图在找不到src时隐藏播放器。

php / mysql / jqm脚本工作正常,我似乎无法获得if / else部分,它总是将播放器显示为空。

<html>
<head>
<script src="http://cdnjs.cloudflare.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
</head>

<script type="text/javascript">
var serviceURL = "http://localhost/Apps/services/";

$(document).on('pageshow', '#detailsPage', function(event) {
    var id = getUrlVars()["id"];
    $.getJSON(serviceURL + 'getartist.php?id='+id, displayArtist);
});

function displayArtist(data) {
    var artistDetVal = data.item;
    console.log(artistDetVal);
    $('#artistDetPic').attr('src', 'pics/lg/' + artistDetVal.picture);
    $('#fullName').text(artistDetVal.firstName + ' ' + artistDetVal.lastName);
    $('#artistDetTitle').text(artistDetVal.bio);
    $('#city').text(artistDetVal.city);
    $('#audioBio').attr('src', 'audio/' + artistDetVal.audio) .detach().appendTo($("#audioPlayer"));
    }

function getUrlVars() {
    var vars = [], hash;
    var hashes = window.location.href.slice(window.location.href.indexOf('?') + 1).split('&');
    for(var i = 0; i < hashes.length; i++)
    {
        hash = hashes[i].split('=');
        vars.push(hash[0]);
        vars[hash[0]] = hash[1];
    }
    return vars;
}
</script>

<body>

<script type="text/javascript">
$(document).ready(function(){

function displayArtist(data) {
var artistDetVal = data.item;
$('#audioBio').text(artistDetVal.audio);

if (artistDetVal.audio>0) {
    $("#audioPlayer").show();
    }
else {
    $("#audioPlayer").hide();
    }
  }
});
</script>

<audio id="audioPlayer" controls="controls"><source id="audioBio" src=""/></audio>

</body>
</html>

1 个答案:

答案 0 :(得分:0)

似乎你的函数displayArtist被宣告两次,这是一个“禁忌”。此外,永远不会调用第二个声明,即控制是否显示或隐藏播放器的声明。

尝试将显示/隐藏播放器的逻辑放在displayArtist的第一个实例中,并完全删除副本。

function displayArtist(data) {
    var artistDetVal = data.item;
    console.log(artistDetVal);
    $('#artistDetPic').attr('src', 'pics/lg/' + artistDetVal.picture);
    $('#fullName').text(artistDetVal.firstName + ' ' + artistDetVal.lastName);
    $('#artistDetTitle').text(artistDetVal.bio);
    $('#city').text(artistDetVal.city);
    $('#audioBio').attr('src', 'audio/' + artistDetVal.audio).detach().appendTo($("#audioPlayer"));

    $('#audioBio').text(artistDetVal.audio);

    if (artistDetVal.audio>0) {
        $("#audioPlayer").show();
    }
    else {
        $("#audioPlayer").hide();
    }
}

此外,如果artistDetVal.audio是字符串,您可能需要使用条件if(artistDetVal.audio.length > 0)