Processing several php processes in one file

Hi, I am looking to be pointed in the right direction. I have an admin panel that I am wanting to revamp. On one page “viewall.php” it pulls all of the rows from a database and puts them in a table. In this table it displays basic info about the record. The last column there is a link that takes that record to “viewpost.php?recordId=25” to view that record more in depth. In this file I have several link’s that allow an admin to edit or delete the post. Again taking that record to “editpost.php?recordId=25” or “deletepost.php?recordId=25”. This all works fine.

I am want in to change my site template to a jquery tab system. What I am wanting help trying to figure out is how I can accomplish this all on one php file without reloading the page. Can this be done? Any and all help is appreciated! Have a good day.

Well the simplest answer would be to use AJAX to load the tab when it would be brought to the forefront. It would still be calling editpost and deletepost and viewpost, but doe it in a way that seems to be without reloading the page.

Thank you starLion.
I have some code that is some what working now. But not sure if I ended up using the correct method. And one of the things I am still trying to make work with the method I am currently using is that the table is not populated until a header is clicked.

This is the code I am including on my tab on index.php


<script type="text/javascript">
								function recp(id) {
								$('#jsContent').load('data.php?id=' + id);
							}
</script>

<table border="1" width="100%">
<thead>
<tr>
<th><a href="#" onClick="recp('date')" >Date Posted</a></th>
<th><a href="#" onClick="recp('category')" >Category</a></th>
<th><a href="#" onClick="recp('author')" >Author</a></th>
<th>...</th>
</tr>
</thead>
<tbody id="jsContent">

</tbody>
</table>

This is the data.php file


$id= $_GET['id'];
  $results = mysql_query("SELECT * FROM records ORDER BY $id");
  if( mysql_num_rows($results) > 0 )
  {
   $row = mysql_fetch_array( $results );


while($row = mysql_fetch_array($results))
  {


  $PostedDate = date("F d, Y", strtotime($row['addedDate']));
  echo "<td>$ " . $PostedDate . "</td>";
  echo "<td>$ " . $row['category'] . "</td>";
  echo "<td>" . $row['author'] ."</td>";
  echo "<td><a href='viewrecord.php?id=" . $row['recordId'] . "'>View</a></td>";
  echo "</tr>";
  }
echo "</table>";
  }

I tried adding this the data.php file to try and get it to populate the table before the a header was clicked.


if(isset($_GET['id']))
{
$id = $_GET['id'];
}
else {	
$id = "accountNumber";
  }

I dont think .load() does what you think it does. I’m going to flag this post for moving into the javascript forum; they’ll be better able to tell you how to achieve the effect you’re attempting.

As a side note, there’s a standard disclaimer we’re putting forward that as of PHP 5.5, mysql_ is deprecated and will be removed entirely in the future, so it’s recommended you move your code to the mysqli_ or PDO libraries. (mysqli_ is virtually identical to mysql_ in functions; at large, you can simply add the “i” and it should still work.)

Hi dxm31,

On your index.php page, is there a reason you’re not pre-populating the table when you generate the page on the server?

Also, with not much extra effort, you could make the page functional even with JS disabled - just have your index.php page take an optional ‘sortby’ param in the URL, and render the table accordingly. For users with JS, your PHP code can detect if the request is via ajax and send only the markup for the table rows rather than rendering the whole page.

Thanks fretburner. Not sure why I didn’t have the table populated with a default query. I have the table working as I was expecting. And yes I had all of this done in PHP already before I started using jquery. I am only making these changes to learn JS. What I am not sure about now I how I can get the post to open in the the same id=“jsContent”.

I’m not quite sure what you’re asking. Using jQuery’s load() function as you showed in your example should work the way you want.