By using this site, you agree to our updated Privacy Policy and our Terms of Use. Manage your Cookies Settings.
435,635 Members | 2,174 Online
Bytes IT Community
+ Ask a Question
Need help? Post your question and get tips & solutions from a community of 435,635 IT Pros & Developers. It's quick & easy.

javascript not passing variable back to PHP

P: n/a
TIA for your help!

I have a page (code snip below) named "browse" which has a table in it with
rows like this:

2003 1500 Silverado pickup red 51,024 $19,995 Details

---------

each row of the table has a hidden id number which is to be passed on to the
next page when the user clicks on "Details" or any other item in the row.

In the code snip below is the javascript that processes the submit when
"Details" is clicked as well as the relevant table code.

When the subsequent page, "details.php" is loaded the following two lines
are executed:
$id = $_REQUEST['d'];
$ids = $_REQUEST['ids'];

In php.ini "register_globals" is off.

The problem is: Both ['d'] and ['ids] appear to be recognized but, $id
returns the correct value of "8", while $ids is "" instead of "'2615631'"

What I don't understand is why one works and the other doesn't.
Could someone explain the difference? I've tried some of the tips given for
using extract without any success.

Thanks
Marty

<html>
<head>
<link href="general.css" rel="stylesheet" type="text/css">

<script language="Javascript">
var marked_row = new Array;
function getDetails(obj)
{ theIDField = eval('document.browse.id'+obj);
theIDField.checked = "true";
document.browse.submit();
return true;
}
</script>

--snipped other code not relevant(I think)

<form method=post name=browse action=details.php><input type=hidden name=d
value="8">
<tr>
<td colspan=9><font color=black>Click Column Headings To
Sort.</font></td>
</tr>
<tr bgcolor=#D93540>
<td colspan=9><p class=bigheading><font
color=#FFFFFF>Chevrolet</font></p></td>
</tr>
<tr>
<td colspan=9><br></td>
</tr>
<tr bgcolor=#eeeeee id=0 onmouseover="highlight(this);"
onmouseout="unhighlight(this);">
<td valign=top><font color=black><input type=checkbox id=id2615631
name=ids[] value="2615631"></font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>2003</font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>1500 SILVERADO</font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>PICKUP</font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>RED</font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>51,024</font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>$19,995</font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black></font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>
<a href=# onClick="getDetails('2615631'); return
true;">Details</a></font></td>
</tr>

<tr bgcolor=#ffffff id=1 onmouseover="highlight(this);"
onmouseout="unhighlight(this);">
<td valign=top><font color=black><input type=checkbox id=id2615581
name=ids[] value="2615581"></font></td>
<td valign=top onClick="getDetails('2615581'); return true;"><font
color=black>2003</font></td><td valign=top

--snipped-repeat entries for multiple lines in table


Dec 21 '05 #1
Share this Question
Share on Google+
1 Reply


P: n/a
Marty Meyers wrote:
TIA for your help!

I have a page (code snip below) named "browse" which has a table in it
with rows like this:

2003 1500 Silverado pickup red 51,024 $19,995 Details

---------

each row of the table has a hidden id number which is to be passed on to
the
next page when the user clicks on "Details" or any other item in the row.

In the code snip below is the javascript that processes the submit when
"Details" is clicked as well as the relevant table code.

When the subsequent page, "details.php" is loaded the following two lines
are executed:
$id = $_REQUEST['d'];
$ids = $_REQUEST['ids'];

In php.ini "register_globals" is off.

The problem is: Both ['d'] and ['ids] appear to be recognized but, $id
returns the correct value of "8", while $ids is "" instead of "'2615631'"
To debug, start on the receiving page with:

<pre>
<? print_r($_POST); ?>
</pre>

or $_GET is you send via URL.

You will probably see that ids is not sent at all or empty.


What I don't understand is why one works and the other doesn't.
Could someone explain the difference? I've tried some of the tips given
for using extract without any success.

Thanks
Marty

<html>
<head>
<link href="general.css" rel="stylesheet" type="text/css">

<script language="Javascript">
var marked_row = new Array;
function getDetails(obj)
{ theIDField = eval('document.browse.id'+obj);
This is bad.
Have a look at document.getElementById('<ID HERE>');
It is the prefered way of getting elements.

theIDField.checked = "true";
I would prefer true instead of the string "true";
Unsure if this could be the cause of troubles.

document.browse.submit();
return true;
}
</script>

--snipped other code not relevant(I think)

<form method=post name=browse action=details.php><input type=hidden name=d
value="8">
Please be less sloppy, for your own good.
If you use name/value pairs, be sure you add the values as string.
Now you sometimes do, sometimes dont.

This is better:
<form method="post" name="browse" action="details.php">
<input type=hidden name="d" value="8">

So you are sending "d" with value "8".
You can retrieve it in detais.php as:
$received_d = $_POST["d"];

<tr>
<td colspan=9><font color=black>Click Column Headings To
Sort.</font></td>
</tr>
<tr bgcolor=#D93540>
<td colspan=9><p class=bigheading><font
color=#FFFFFF>Chevrolet</font></p></td>
</tr>
<tr>
<td colspan=9><br></td>
</tr>
<tr bgcolor=#eeeeee id=0 onmouseover="highlight(this);"
onmouseout="unhighlight(this);">
<td valign=top><font color=black><input type=checkbox id=id2615631
name=ids[] value="2615631"></font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>2003</font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>1500 SILVERADO</font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>PICKUP</font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>RED</font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>51,024</font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>$19,995</font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black></font></td>
<td valign=top onClick="getDetails('2615631'); return true;"><font
color=black>

Well, you send a string to getDetails, the same string in all cases.

But in your getDetails you receive it named as 'obj'.
Why do you confuse yourself so much with bad names?
It is not an Object, it is a string.

What you should do is this (if I understand you right):

You want the value '2615631' send to the receiving script if somebody hits
the td, ok?

So just add to your form:
<input type="hidden" name="whatever_ids?" value="NA">

replace whatever_ids? with a good name of course.

ANd in your getdetails function:
getDetails(someString){
document.forms["browse"]["whatever_ids?"].value=someString;
document.forms["browse"]submit();

}

Regards,
Erwin Moller

PS: Debugging starts with:
1) in receiving script print the posting with pre and print_r()
2) in JS: use alert() to check your values.

<a href=# onClick="getDetails('2615631'); return
true;">Details</a></font></td>
</tr>

<tr bgcolor=#ffffff id=1 onmouseover="highlight(this);"
onmouseout="unhighlight(this);">
<td valign=top><font color=black><input type=checkbox id=id2615581
name=ids[] value="2615581"></font></td>
<td valign=top onClick="getDetails('2615581'); return true;"><font
color=black>2003</font></td><td valign=top

--snipped-repeat entries for multiple lines in table


Dec 22 '05 #2

This discussion thread is closed

Replies have been disabled for this discussion.