Ravinder Singh
Ravinder Singh

Reputation: 3133

How to stop the user from submitting form when javascript is disabled on the user's browser?

I am having a form in which i have applied the javascript validations, but if the user has javascript disabled then those validations does not work, please help me that how can i stop the user from submitting form until & unless he enables the javascript. Thanks

Upvotes: 2

Views: 3683

Answers (5)

SagAr PatEl
SagAr PatEl

Reputation: 1

javascriptdemo.html

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"     "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>JAVASCRIPTDEMO</title>
<script language="javascript" type="text/javascript">
function onset()
{

document.forms["jdemoform"].elements["uname"].focus();

}
function jdemo()
{
if(document.forms["jdemoform"].elements["uname"].value=="")
{
    alert("fill your name");
    document.forms["jdemoform"].elements["uname"].focus();
    return false;
}

    document.forms["jdemoform"].submit();

}
</script>
</head>
<body onload="onset();">
if javascript disabled then form will not be submitted
<form name="jdemoform" method="post" action="getname.php">
Name:<input type="text" name="uname" />
<input type="button" value="Submit" onClick="return jdemo();"/>
</body>
</html>

                           getname.php

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>JAVASCRIPTDEMO</title>
</head>
<?php
echo $_POST["uname"];
?>
<body>
</body>
</html>

Upvotes: -2

Tessmore
Tessmore

Reputation: 1039

You can use javascript validation, but note that javascript is just for adding more usability (i.e use it to make form submission easier for the client). Without javascript a form should still be submittable, partially for the small user-base which doesn't have javascript enabled by default.

partially because of a very small user base who otherwise will pwn you in the face for only using client side javascript validation and can (and probably will try at some point) to bypass this. So this is why server validation is a must, not only for the small user base without javascript.

Then ofcourse to answer your question, for the small user-base who wont try to manipulate your database or server you could remove your <form> and use:

<noscript>
  You can FORM_BEHAVIOUR me with javascript enabled.
</noscript>

<script>
  create a form here with javascript
</script>

How exactly you want to render your form is then ofcourse up to you, but note that no javascript can stop the very-small user base from abusing it.

Upvotes: 0

James.Xu
James.Xu

Reputation: 8295

you cannt, on the client side. But you can still do validation on the server side. Essentially, server-side validation is what really matters.

Upvotes: 1

Niet the Dark Absol
Niet the Dark Absol

Reputation: 324650

Use JavaScript to put the submit button there.

<script type="text/javascript">
    document.write("<input type=\"submit\" value=\"Submit Form\" />");
</script>
<noscript>
    <p style="color: red;"><b><i>Please enable JavaScript to continue</i></b><p>
</noscript>

Upvotes: 10

Darin Dimitrov
Darin Dimitrov

Reputation: 1038890

You could add the disabled="disabled" attribute on your submit button. Then using javascript when the DOM is loaded remove this attribute.

Upvotes: 7

Related Questions