I’m working with AJAX on a website and I’m currently making some pages to load on a certain div: “pageContent”. Now I have another content I want to be opened on another div: “reproductor”. I want to open ‘page’ in ‘pageContent’ div and ‘play’ in ‘reproductor’ div. I don’t know how to modify my script.js and load_page.php files in order to make it work. Here’s what I got:
HTML:
<script type="text/javascript" src="js/script.js"></script>
<a href="#page1">PAGE</a>
<a href="#play1">PLAY</a>
<div id ="pageContent"></div>
<div id="reproductor"></div>
script.js:
var default_content="";
$(document).ready(function(){
checkURL();
$('ul li a').click(function (e){
checkURL(this.hash);
});
default_content = $('#pageContent').html();
setInterval("checkURL()",250);
});
var lasturl="";
function checkURL(hash)
{
if(!hash) hash=window.location.hash;
if(hash != lasturl)
{
lasturl=hash;
if(hash=="")
$('#pageContent').html(default_content);
else
loadPage(hash);
}
}
function loadPage(url)
{
url=url.replace('#page','');
$('#loading').css('visibility','visible');
$.ajax({
type: "POST",
url: "load_page.php",
data: 'page='+url,
dataType: "html",
success: function(msg){
if(parseInt(msg)!=0)
{
$('#pageContent').html(msg);
$('#loading').css('visibility','hidden');
}
}
});
}
load_page.php:
<?php
if(!$_POST['page']) die("0");
$page = (int)$_POST['page'];
if(file_exists('pages/page_'.$page.'.html'))
echo file_get_contents('pages/page_'.$page.'.html');
else
echo 'There is no such page!';
?>
I forgot to mention: I have my ‘pages’ content in a folder named ‘pages’ and my ‘play’ content in another named ‘plays’.
Thanks for your help!
If I understand, your have two groups of links (for pages and a play list) each one to be loaded in a different container. Here is something you can try: mainly I eliminated the global variables and put the current hash inside each containter’s data, and separated the management of the two groups of links.
In this code I supposed you have a separate
load_play.phpfile. If not, then you can use the same page for both kind of links, but you’ll have to mergeloadPlaywithloadPage, changeloadPage(newHash)toloadPage(newHash, linkType)and change the ajax parameter from'page='+newHashto'number='+newHash+'&type='+linkType, and do the corresponding changes server side in your PHP page. I would recommend you to create two separate PHP files in order to manage the two types of content.I remember you where doing something with the hash of the current page’s url, you can still set it in the ajax’s success, inside the
loadPagefunction.Here is a working sfiddle example with some console calls (open browser’s console) but without the ajax call.
UPDATE:
I updated the code, so your can manage the dynamically added links (new content loaded via AJAX) and fixed the management of urls with hashes, which was broken because of the new code.
And this is the javascript:
Check this and comment if this is what you need, or I got something wrong 🙂