Solved

Dynamic Redirect

Posted on 2009-07-11
5
359 Views
Last Modified: 2013-12-13
I am trying to create a form that uses a dynamic type of redirect. I was hoping for a php or javascript solution (if it even exists)

For example:

I will have two radio buttons (one is YES and the second one is NO). I will also have a submit button labeled NEXT.

If YES is pressed and the Next Button is selected the user would go to Page 1.

If NO is pressed and the Next Button is selected the user would go to Page 2.

Thanks in advance experts
0
Comment
Question by:bmw040
5 Comments
 
LVL 4

Assisted Solution

by:Xemorph
Xemorph earned 150 total points
ID: 24830873
Try this:
<html>
<head>
 <script type="text/javascript">
   function redirect(){
     var yes = document.getElementById('yes').checked;
  
     if(yes) window.location="page1.html";
     else window.location="page2.html";
 
   }
 </script>
</head>
<body>
   <input type="radio" id="yes" /> Yes <br />
   <input type="radio" id="no"  /> No <br />
   <input type="button" value="NEXT" onclick="redirect()" />
</body>
</html>

Open in new window

0
 
LVL 4

Expert Comment

by:Xemorph
ID: 24830878
Sorry, one error in my code.  add the name attribute to both radio buttons.  Make them the same.
0
 
LVL 109

Accepted Solution

by:
Ray Paseur earned 200 total points
ID: 24831045
You may want to process other information in the form, and to do that you may want to run a script on the server-side, instead of on the client-side in JavaScript.  If that is the case, this code will show you the way to do the dynamic redirect.

best regards, ~Ray
<?php // RAY_radio_redirect.php
error_reporting(E_ALL);
 
 
// GUIDANCE COPIED FROM THE OP
// If YES is pressed and the Next Button is selected the user would go to Page 1.
// If NO  is pressed and the Next Button is selected the user would go to Page 2.
 
 
// IF ANYTHING IS POSTED
if (!empty($_POST["my_radio"]))
{
 
 
//
// VALIDATE THE CONTENTS OF $_POST AND UPDATE A DATA BASE, ETC.
//
 
 
// SET THE DEFAULT (ERROR) PAGE
    $page = 'error.html';
 
// DETERMINE WHERE TO REDIRECT
    if ($_POST["my_radio"] == 'y') $page = 'page1.html';
    if ($_POST["my_radio"] == 'n') $page = 'page2.html';
 
// REDIRECT AND EXIT
    header("Location: $page");
    exit;
    
} // END OF PHP - PUT UP THE FORM WITH THE RADIO BUTTONS
?>
 
<form method="post">
<input type="radio" name="my_radio" value="y" />YES (PAGE 1)<br />
<input type="radio" name="my_radio" value="n" />NO (PAGE 2)<br />
<input type="submit" />
</form>

Open in new window

0
 
LVL 14

Assisted Solution

by:profya
profya earned 150 total points
ID: 24847666

<html>
<head>
 <script type="text/javascript">
   function GoToUrl(){
		var userOptions=document.forms[0].elements['userOption'];
		if (userOptions[0].checked)
			window.location=userOptions[0].value;
		else
			window.location=userOptions[1].value;
   }
 </script>
</head>
<body>
	<form>
   <input name="userOption" type="radio" value="www.domain1.com" checked/><label for="userOptions">www.domain1.com</label>
   <input name="userOption" type="radio" value="www.domain2.com"  /><label for="userOptions">www.domain2.com</label>
   <input type="button" value="Go" onclick="GoToUrl()" />
   </form>
</body>
</html>

Open in new window

0
 

Author Closing Comment

by:bmw040
ID: 31602435
Thanks for the solution!
0

Featured Post

Free Tool: IP Lookup

Get more info about an IP address or domain name, such as organization, abuse contacts and geolocation.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Preface This is the third article about the EE Collaborative Login Project. A Better Website Login System (http://www.experts-exchange.com/A_2902.html) introduces the Login System and shows how to implement a login page. The EE Collaborative Logiā€¦
3 proven steps to speed up Magento powered sites. The article focus is on optimizing time to first byte (TTFB), full page caching and configuring server for optimal performance.
The viewer will learn how to dynamically set the form action using jQuery.
The viewer will learn the basics of jQuery, including how to invoke it on a web page. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery.: (CODE)

808 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question