Form Submission decides URL

I have a PHP form with a few fields that will be entered into my database when I click Submit but I also have 2 radio buttons one YES and one NO.  These ask if more info is needed, so if YES is selected I need to be directed to the MoreInfo.php page if NO is selected I need to go to NewEntry.php page.  How do I do this?
Thanks
napsternovaDeveloperAsked:
Who is Participating?
 
Jason C. LevineConnect With a Mentor No oneCommented:
Hi napternova,

In the PHP that processes the form, you will check the value of the selected radio button and then set a redirect based on that value:

if ($_POST['your_radio'] == "Yes") {
   $redirect_to = "MoreInfo.php";
} else {
   $redirect_to = "NewEntry.php";
}

header("Location: $redirect_to");
0
 
Cornelia YoderArtistCommented:
Or, you could just

if ($_POST['your_radio'] == "Yes") {
   include "MoreInfo.php";
} else {
   include "NewEntry.php";
}
0
 
rfportillaCommented:
Use javascript.  On the form tag, add
  onsubmit="setaction()")

Then create a function called set action that looks for the selected radio button.  Then modify the form action based on that. While you are at it, set return values.  If it turns out that a radio button was not selected, alert the user and return false.  The false value will prevent the form submission.  Return true if everything checks out ok.
0
Cloud Class® Course: Amazon Web Services - Basic

Are you thinking about creating an Amazon Web Services account for your business? Not sure where to start? In this course you’ll get an overview of the history of AWS and take a tour of their user interface.

 
rfportillaCommented:
I think something along these lines...

It has to be adapted a little for your html.  
<script type=text/javascript
//repace myformname and radioname with appropriate values for your 
//html tag names

function get_radio_value()
{
for (var i=0; i < document.myformname.radioname.length; i++)
   {
   if (document.myformname.radioname[i].checked)
      {
         var rad_val = document.myformname.radioname[i].value;
      }
   }
return rad_val();
}

function setaction() {
var radval = get_radio_value();
if (radval == 'YES') 
   {
      document.myformname.action = 'MoreInfo.php';
   } else {
      document.myformname.action = 'NewEntry.php';
   } 
}
</script>

Open in new window

0
 
Ray PaseurCommented:
I think I would use a single PHP action script, and would not do any redirect.  It will be easier to debug your code this way.  

You have to process the <form> data, so you would do that first.  Then the script would test the radio button to decide what HTML needed to be generated next.

I like yodercm's suggestion to use include() to load the scripts that generate the different follow-on pages.
0
 
napsternovaDeveloperAuthor Commented:
OK so based on the responses I should probably not be haveing an issue with this, but I am.  I'm going to try and make it easier on myself and instead of 2 radio buttons how about 1 checkbox?  So the database is set to default N.  The checkbox if checked should pass Y.  So if the box is checked and I hit Submit I should go to MoreInfo.php.  Now I made a slim version of my form.  I just want it to default to NewEntry.php  and when checked MoreInfo.php  Here is my checkbox code.
<input type="checkbox" name="Check" value="Y"<?php if ($Check == "Y") { echo " checked"; } ?> />
0
 
napsternovaDeveloperAuthor Commented:
Bad spelling, sorry

OK so based on the responses I should probably not be having an issue with this, but I am.  I'm going to try and make it easier on myself and instead of 2 radio buttons how about 1 checkbox?  So the database is set to default N.  The checkbox if checked should pass Y.  So if the box is checked and I hit Submit I should go to MoreInfo.php.  Now I made a slim version of my form.  I just want it to default to NewEntry.php  and when checked MoreInfo.php  Here is my checkbox code.
<input type="checkbox" name="Check" value="Y"<?php if ($Check == "Y") { echo " checked"; } ?> />

0
 
napsternovaDeveloperAuthor Commented:
By making a very simple application I was better able to deconstruct the code.  Thanks, works like a charm.
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.