1

我需要这方面的帮助,我希望当用户为字段(例如“ThePassword”)键入正确的值时显示一个 div。这是我到目前为止所拥有的:

<input type="text" name="vip-code" id="vipcode" value="" />
<div id="container" style="display:none;"></div>

<script>
$(function () {
var validcode = "ThePassword";
$("#vipcode").focusout(function () {
    $(this).keyup(function () {
        var code = $(this).val();
        if (this === validcode) {
            $("#container").css("display", "block");
        } else {
            $("#container").css("display", "none");
        }
    });
});
});
</script>

有任何想法吗?

提前致谢。

4

2 回答 2

2

不确定句柄keyup事件是否正确,但问题是:您正在validcode与输入字段进行比较,vip-code而不是code变量...

if (code === validcode) {
    $("#container").css("display", "block");
} else {
    $("#container").css("display", "none");
}
于 2015-02-18T15:09:15.250 回答
0

在您的代码中,一旦 vipcode 输入失去焦点,您只会绑定到 keyup 事件,因此很有可能永远不会触发 keyup 事件。值得一提的是,在客户端硬编码密码是非常糟糕的做法,因为它是一个巨大的安全漏洞。

<input type="text" name="vip-code" id="vipcode" value="" />
<div id="container" style="display:none;"></div>

<script>
  $(function () {
    var validcode = "ThePassword";
    $("#vipcode").keyup(function () {
        var code = $(this).val();
        if (code === validcode) {
            $("#container").show();
        } else {
            $("#container").hide();
        }
    });
  });
</script>

http://jsfiddle.net/uuy6ovf6/2/

于 2015-02-18T15:11:26.630 回答