Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/jquery/86.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/ajax/6.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Jquery只播放一次声音_Jquery_Ajax_Notifications_Audio - Fatal编程技术网

Jquery只播放一次声音

Jquery只播放一次声音,jquery,ajax,notifications,audio,Jquery,Ajax,Notifications,Audio,我需要jQuery在用户收到新消息时播放通知声音。这是我的代码和未读消息和声音的计数。问题是,当用户收到新消息时,它会每隔0.1秒播放一次声音,直到用户阅读为止。我只需要播放一次,当用户收到另一条消息时再播放一次 function pullNewMessageCount() { var url = 'messenger/bubble.php'; $.ajax({

我需要jQuery在用户收到新消息时播放通知声音。这是我的代码和未读消息和声音的计数。问题是,当用户收到新消息时,它会每隔0.1秒播放一次声音,直到用户阅读为止。我只需要播放一次,当用户收到另一条消息时再播放一次

    function pullNewMessageCount() {
                    var url = 'messenger/bubble.php';
                    $.ajax({
                        url: url,
                        dataType: 'html',
                        type: 'POST',
                        success: function(latestCount) {
                            setTimeout('pullNewMessageCount()', 200);
                            $('#bub').html(latestCount);
                            if (latestCount > 0)
                            { 
                                $('#bub').removeClass('hidden').addClass('bubble').addClass('animating');
playSound('message');
                            } else if ((latestCount = $('#bub').html()) && (latestCount > 0)) {
                                $('#bub').removeClass('animating');                              
                            } else if ((latestCount = '0') || (!latestCount)) {
                                $('#bub').removeClass('bubble').addClass('hidden');
                            } else {
                                $('#bub').removeClass('bubble').addClass('hidden');
                            }
                        },
                        error: function(jqXHR, textStatus, errorThrown) {
                        }
                    });
                }

您需要存储latestCount值,并且仅在latestCount低于当前计数时播放声音,而不是在>0时始终播放


当新消息可用时,latestCount将再次低于当前计数,导致声音再次播放。

playSound函数的定义是什么?函数pullNewMessageCount()是执行一次,还是每0.1秒执行一次?每0.1秒执行一次。函数playSound(filename){document.getElementById(“bub”).innerHTML='';如何存储它?我认为它会在每次函数调用中重置变量。您可以将其存储在页面上的隐藏字段中: