4

我正在尝试为用户输入数据显示 Javascript 提示(因为提示用于)。但是,它不会显示。window.alert 显示,window.confirm 也显示。但是,不及时。这是我要运行的代码:

var is_expired = document.getElementById("is_expired").value;
    if (is_expired == "yes") {
        alert(is_expired);
        var answer = prompt("Are you sure you?");
        alert(answer);
    }

当它运行时,将输入 if 语句。第一个警报应显示“是”。但是,它会跳过提示行。下一个警报显示“未定义”。

现在,如果我唯一更改的是关键字提示,它将起作用,如下所示:

var is_expired = document.getElementById("is_expired").value;
    if (is_expired == "yes") {
        alert(is_expired);
        var answer = confirm("Are you sure you?");
        alert(answer);
    }

当我运行它时,会出现确认框。如果我单击 Okay,则下一个警报会显示“true”,如果单击 Cancel,则警报会显示“false”。

所以,这里最大的收获是没有导致 Javascript 停止的语法错误。它实际上跳过了那一行并继续执行。那条线有什么问题?我检查了多个站点以确保它是正确的。添加第二个“默认”参数也无济于事。我试过了。此外,没有 Javascript 错误来指示问题。

我去了这里并将其更改为我的代码(我将 is_expired 硬编码为是),它在那里工作。

任何帮助都会很棒。谢谢。

编辑:需要明确的是,我并不依赖 W3school 的示例来准确,我使用他们的“试用”页面来测试我自己的代码。我也在 jfiddle 上做了这个,效果很好。使用控制台检查函数返回“未定义”。

EDIT2:实际上,从头开始。当控制台中没有命令时,我不小心再次按了 Enter。提示的实际输出是:

[12:07:55.940] [object Function]
4

3 回答 3

3

prompt应该几乎可以在每个浏览器中使用。一种可能性是检查您是否没有在源代码的某处意外覆盖此函数。如果您prompt在网站上输入浏览器控制台,它应该会显示如下内容:

> prompt
function prompt() { [native code] }

// or put in your code:
alert(window.promt);

否则它会以某种方式被覆盖(很可能是因为忘记了var关键字):

> prompt = function(){alert("foo!")}
> prompt
function (){alert("foo")}

// calling prompt() would now pop an alert box
于 2013-09-09T15:48:02.417 回答
2

在函数中声明变量时,请确保使用var关键字,以免破坏全局命名空间。听起来你在某处这样做:

function my_thing() {
    var i = 0;
    var j = 0;
    prompt = "What the heck";
}

省略var关键字 putsprompt在全局命名空间中,破坏了默认prompt函数。

于 2013-09-09T15:47:56.150 回答
2

如建议的那样,您的代码中的某些内容已window.promptfunction prompt(s) { window.status = s }. 不确定这是不是故意的。

您可以使用几种方法来“恢复”原始prompt.

  1. 您可以在页面的最开始备份原件:

    var originalPrompt = window.prompt;
    // Whatever code is on your page
    function prompt(s) { window.status = s }
    

    然后originalPrompt改用:

    var answer = originalPrompt("Are you sure you?");
    
  2. 您可以delete window.prompt;(或设置window.prompt = null;),尽管这可能不适用于所有浏览器。

  3. 您可以创建一个 iframe(它创建一个新window环境),然后prompt从那里“窃取”。

    var i = document.createElement('iframe');
    i.style.display = 'none';
    document.body.appendChild(i);
    window.prompt = i.contentWindow.prompt;
    
于 2013-09-09T17:19:21.637 回答