I've got a <select
element on a php/xhtml page. Instead of using a submit button, I'm trying to implement the Javascript onchange()
and submit()
method. I need to pass multiple variables to make up for the lost hidden field. The onchange and submit methods are firing, but I can't get it to trigger the PHP isset which is on the same page.
<?php
if(isset($_POST['companykey'])){
$nowIveGot1 = $_POST['COMPANYKEY'];
$nowIveGot2 = $_POST['USERNAME'];
?>
<script language="javascript">
function copy(selectedValuePassed, selectedNamePassed, userIDPassed, formNamePassed) {
var formNameReceived = formNamePassed;
var userIDReceived = userIDPassed;
var selectedValueReceived = selectedValuePassed;
var selectedNameReceived = selectedNamePassed;
var form = document.createElement("form");
form.setAttribute("method", "post");
form.setAttribute("action", "");
form.setAttribute("name", formNameReceived);
form.setAttribute("id", formNameReceived);
var valueSelected = document.createElement("input");
valueSelected.setAttribute("type", "hidden");
valueSelected.setAttribute("name", selectedNameReceived);
valueSelected.setAttribute("id", selectedNameReceived);
valueSelected.setAttribute("value", selectedValueReceived);
form.appendChild(valueSelected);
var passusername = document.createElement("input");
passusername.setAttribute("type", "hidden");
passusername.setAttribute("name", "USERNAME");
passusername.setAttribute("id", "USERNAME");
passusername.setAttribute("value", userIDReceived);
form.appendChild(passusername);
document.body.appendChild(form);
form.submit();
}
</script>
<select onchange="copy(this, 'COMPANYKEY','jarrett', 'companykey');">
<option value="Text1">Text 1</option>
<option value="Text2">Text 2</option>
</select>
SOLVED: Create a parent element for valueSelected and passusername. Name it the isset check name.