3

jQueryスクリプトが添付された、以下のような単純なログインフォームがあります。jQueryを使用して、簡単なクライアント側のフォーム検証を作成しようとしています。ただし、ぼかしイベントを発生させることができないようです。私が間違っていることを考えることはできません。助けてください!

これが私のHTMLファイルです:

<!doctype html>
<html>
    <head>
        <meta charset="utf-8">
        <title>DMIT 222 - Catalogue Project: Admin Login</title>
        <link rel="stylesheet" type="text/css" href="../styles/divs.css" />
        <link rel="stylesheet" type="text/css" href="../styles/fonts.css" />
        <link rel="stylesheet" type="text/css" href="../styles/tags.css" />
        <link rel="stylesheet" type="text/css" href="../styles/tables.css" />
        <link rel="stylesheet" type="text/css" href="styles/forms.css" />
        <script src="http://code.jquery.com/jquery-latest.js"></script>
        <script src="../scripts/loginFormValidation.js"></script>
    </head>
    <body>
        <div id="wrapper">
            <header>
                <h1>Ship Catalogue</h1>
            </header>
            <div id="mainContent">
                <form id="LoginForm" name="LoginForm" method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>">
                    <div class="FormRow"><label for="Username">Username:</label><input type="text" name="Username" id="Username" /><p id="userErrors"><?php echo $userErrors; ?></p></div>
                    <div class="FormRow"><label for="Password">Password:</label><input type="password" name="Password" id="Password" /><p id="passwordErrors"><?php echo $passwordErrors; ?></p></div>
                    <div class="FormRow"><input type="submit" name="Submit" value="Login!" /></div>
                </form>
            </div>
            <footer>
                <a href="http://www.logicanddesign.ca/">Site Developed by Logic &amp; Design</a>
            </footer>
        </div>
    </body>
</html>

loginFormValidation.js スクリプトは次のとおりです。

$("#Username").blur(function(e){
    alert();
    if ($("#Username").val() == "") {
        $("#userErrors").text("Username must be entered!");
    }
});

$("#Password").blur(function(e){
    if ($("#Password").val() == "") {
        $("#passwordErrors").text("Password must be entered!");
    }
});
4

3 に答える 3

3

イベントを jQuery の document.ready 関数内にラップする必要があります。

$(document).ready(function() {
    $("#Username").blur(function(e){
       alert();
        if ($("#Username").val() == "") {
            $("#userErrors").text("Username must be entered!");
        }
    });

    $("#Password").blur(function(e){
        if ($("#Password").val() == "") {
            $("#passwordErrors").text("Password must be entered!");
        }
    });
});
于 2012-12-02T09:11:44.403 に答える
1

アラートにコンテンツを追加すると機能します。アラート関数がパラメーターなしで呼び出されたため、JS エンジンはエラーをスローしました。イベントをバインドすることもお勧めしますdocument.ready()

$(document).ready(function(){
    $("#Username").blur(function(e){
        alert("something");
        if ($("#Username").val() == "") {
            $("#userErrors").text("Username must be entered!");
        }
    });
});

例: http://jsfiddle.net/PfnGv/

于 2012-12-02T09:13:11.283 に答える
1

jqueryぼかしコードを内部に追加するか

$(document).ready(function() { ...// your blur code here }

または、ページの下部にあるbodyタグを閉じる:

<script type="text/javascript">
//your blur code
</script>

</body>
于 2012-12-02T09:13:43.737 に答える