I have a simple HTML form:
<form id="frmNewCategory">
<span>New Category Name:</span>
<input type="text" id="txtNewCategoryName">
<label>Amount:</label>
<input type="text" id="txtNewCategoryAmount">
<br>
<input type="submit" value="Create" class="importantButton button" id="btnNewCategory">
<input type="button" value="Cancel" class="button" id="btnCancelNewCategory">
</form>
And a bit of jQuery-driven JavaScript using the validation plugin that fires when btnNewCategory is clicked:
function onNewCategoryClick(event)
{
$("#frmNewCategory").validate(
{
rules:
{
txtNewCategoryName : { required: true },
txtNewCategoryAmount : { required: true, number: true }
},
messages:
{
txtNewCategoryName : { required: "*" },
txtNewCategoryAmount: { required: "*", number: "Invalid Amount." }
}
});
if (!$("#frmNewCategory").valid())
return;
event.preventDefault();
var cmd = cmdFactory.createUndoableNewCategoryCommand($(this));
cmdBus.handleCommand(cmd);
}
The method above is supposed to validate frmNewCategory. Trouble is that even if the form has invalid values or no values at all the .valid() method still returns True.
Any ideas? What am I doing wrong?
I have a simple HTML form:
<form id="frmNewCategory">
<span>New Category Name:</span>
<input type="text" id="txtNewCategoryName">
<label>Amount:</label>
<input type="text" id="txtNewCategoryAmount">
<br>
<input type="submit" value="Create" class="importantButton button" id="btnNewCategory">
<input type="button" value="Cancel" class="button" id="btnCancelNewCategory">
</form>
And a bit of jQuery-driven JavaScript using the validation plugin that fires when btnNewCategory is clicked:
function onNewCategoryClick(event)
{
$("#frmNewCategory").validate(
{
rules:
{
txtNewCategoryName : { required: true },
txtNewCategoryAmount : { required: true, number: true }
},
messages:
{
txtNewCategoryName : { required: "*" },
txtNewCategoryAmount: { required: "*", number: "Invalid Amount." }
}
});
if (!$("#frmNewCategory").valid())
return;
event.preventDefault();
var cmd = cmdFactory.createUndoableNewCategoryCommand($(this));
cmdBus.handleCommand(cmd);
}
The method above is supposed to validate frmNewCategory. Trouble is that even if the form has invalid values or no values at all the .valid() method still returns True.
Any ideas? What am I doing wrong?
Share Improve this question edited Oct 17, 2012 at 6:42 Adrian Heine 4,1313 gold badges32 silver badges43 bronze badges asked Sep 2, 2010 at 4:43 willemwillem 27k23 gold badges79 silver badges118 bronze badges3 Answers
Reset to default 14The rules take form input "names" not "ids":
<input type="text" name="txtNewCategoryName" />
<input type="text" name="txtNewCategoryAmount" />
Instead of:
<input type="text" id="txtNewCategoryName">
<input type="text" id="txtNewCategoryAmount">
Use:
<input type="text" name="txtNewCategoryName">
<input type="text" name="txtNewCategoryAmount">
This pattern worked for me before:
$(".required").filter(function () { return $(this).val() == ""; }).addClass("invalidInput");
if (this.formWrp.valid() && this.formWrp.find(".invalidInput").length == 0)
return true;
After doing so, it seems that validation is activated.