等待用户事件

Luc*_*uca 5 javascript jquery events popup wait

我正在开发一个 javascript 类(使用 jQuery)来创建自定义弹出窗口,但我不知道如何“暂停”脚本以等待用户响应(单击“确定”按钮或取消)

班级是这样的:

function Popup()
{
}

Popup.Show = function(text)
{
    var _response;
    /* code to draw the popup elements*/

    $("#button-ok").on("click",function()
    {
        _response = "ok!"
    }

    return _response
}
Run Code Online (Sandbox Code Playgroud)

例如,如果在警报中使用它,该方法总是返回“未定义”,因为它不等待用户点击

alert(Popup.Show("hello"))
//return undefined before the popup appears
Run Code Online (Sandbox Code Playgroud)

我尝试使用这样的 while 循环:

Popup.Show = function(text)
{
    var _response;
    var _wait = true;

    /* code to draw the window */

    $("#button-ok").on("click",function()
    {
        _wait = false;
        _response = "ok!"
    }

    while(_wait){};

    return _response
}
Run Code Online (Sandbox Code Playgroud)

但不起作用(如我所料)

那么,如何等待用户点击呢?

谢谢大家

jHi*_*her 0

这是一个典型的 JavaScript 问题。

$("#button-ok").on("click",function()
{
    _response = "ok!"
}

return _response
Run Code Online (Sandbox Code Playgroud)

现在让我们看看这里发生了什么。您正在为该按钮设置一个 onClick 侦听器,并为该事件分配一个回调函数。将该函数视为传递给另一个函数的参数。它不是直接执行的。

现在,您应该使用该回调,而不是使用类似的东西 while(_wait){};并强制它同步执行。

 Popup.Show = function(text)
 {

    $("#button-ok").on("click",function()
    {
           drawSomething('ok');
    }

 };

var drawSomthing = function(response) {
 // do something
 };
Run Code Online (Sandbox Code Playgroud)

这是回调的一个很好的开始:http://javascriptissexy.com/