3

我需要在我的脚本中添加哔声。我每次都添加,当声音必须是。

$("#beep").html("<embed src='button-16.wav' hidden='true' autostart='true' loop='false' id='bp' />")

但是当我添加时,我失去了焦点。

我尝试通过以下方式再次集中注意力。

1)

$("#beep").html("<embed src='button-16.wav' hidden='true' autostart='true' loop='false' id='bp' />");
$("#txt").focus();

2)

$("#beep").html("<embed src='button-16.wav' hidden='true' autostart='true' loop='false' id='bp' />");
$("#bp").ready(function(){
    $("#txt").focus(); 
});

但是第一种方法和第二种方法都不起作用。

HTML 代码。

<div id="beep"></div>
<input type="text" id="txt" />

那么,如何在哔声后保存文本框的焦点?

4

2 回答 2

0

你可以尝试设置一个间隔来查看wav文件的结尾是否抓住了焦点?

setInterval(function() {
  $("#txt").focus(); 
}, 100);

我仅出于故障排除目的而推荐此方法……而不是实际修复。执行 .wav 可能比运行下一个进程(即你的 focus() )花费更长的时间

于 2011-03-16T00:00:43.133 回答
0

我找到了完全不同的方法来解决这个问题。我编写了 *.swf,它会在 JavaScript 调用它的函数时发出哔声。

动作脚本代码。

package  {
import flash.display.*;
import flash.events.*;
import flash.system.*;
import flash.media.Sound;
import flash.net.URLRequest;
import flash.external.ExternalInterface;

public class Main extends Sprite {
    var s:Sound;
    public function Main() 
    {
        ExternalInterface.addCallback("PlaySound", PlaySound);
        var request:URLRequest = new URLRequest("beep.mp3");
        s = new Sound(request);
    }
    public function PlaySound():void
    {
        s.play();
    }
}
}

JavaScript 代码。

$("#txt").keyup(function(event){
    if(event.which==13){
     var obj=thisMovie("Main");
     obj.PlaySound();
    }
});

function thisMovie(movieName) {
var movie;
try
{
    movie = document[movieName];
    movie = (movie == null) ? window[movieName] : movie;        
}
catch (e)
{
    return null;
}
return movie;
}
于 2011-03-17T10:05:27.760 回答