最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

function - Plain Javascript (no JQuery) to load a php file into a div - Stack Overflow

programmeradmin1浏览0评论

Hi I don't know javascript but I am required to use it in one of my templates. I was googling around and found a solution whic is like this:

My Index.php file.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" ".dtd">
<html xmlns="">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Test</title>
<script type="text/javascript">
window.onload = function(){
document.getElementById("aside").innerHTML="<img src='loadingImage.gif'>";
if(XMLHttpRequest) var x = new XMLHttpRequest();
else var x = new ActiveXObject("Microsoft.XMLHTTP");
x.open("GET", "other_content_1.php", true);
x.send("");
x.onreadystatechange = function(){
    if(x.readyState == 4){
        if(x.status==200) document.getElementById("aside").innerHTML = x.responseText;
        else document.getElementById("aside").innerHTML = "Error loading document";
        }
    }
} 
</script>
</head>

<body>

<div id="aside">This is aside</div>
</body>
</html>

My other_content_1.php file

<div id='other-content-1'>
<?php echo 'This text is loading via php mand'; ?>
</div>

As this is the only Javascript function in my site I see no reason to load additional JQuery for it. I am sure there must be a way to do this with plain JavaScript / ajax without the need to load JQuery. Can anybody suggest the correct syntax to do so?

I want to happen asynchronously while the page continues to load.

Hi I don't know javascript but I am required to use it in one of my templates. I was googling around and found a solution whic is like this:

My Index.php file.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Test</title>
<script type="text/javascript">
window.onload = function(){
document.getElementById("aside").innerHTML="<img src='loadingImage.gif'>";
if(XMLHttpRequest) var x = new XMLHttpRequest();
else var x = new ActiveXObject("Microsoft.XMLHTTP");
x.open("GET", "other_content_1.php", true);
x.send("");
x.onreadystatechange = function(){
    if(x.readyState == 4){
        if(x.status==200) document.getElementById("aside").innerHTML = x.responseText;
        else document.getElementById("aside").innerHTML = "Error loading document";
        }
    }
} 
</script>
</head>

<body>

<div id="aside">This is aside</div>
</body>
</html>

My other_content_1.php file

<div id='other-content-1'>
<?php echo 'This text is loading via php mand'; ?>
</div>

As this is the only Javascript function in my site I see no reason to load additional JQuery for it. I am sure there must be a way to do this with plain JavaScript / ajax without the need to load JQuery. Can anybody suggest the correct syntax to do so?

I want to happen asynchronously while the page continues to load.

Share Improve this question edited Jun 30, 2013 at 16:10 Vikram Rao asked Jun 30, 2013 at 14:45 Vikram RaoVikram Rao 1,0784 gold badges25 silver badges62 bronze badges 6
  • 1 That jQuery is probably cached in your browser anyway, so..why bother? Just google pure javascript AJAX tutorial – Itay Moav -Malimovka Commented Jun 30, 2013 at 14:47
  • Really, why would you NOT want to use jQuery? The (great) answer below works but pared it to the jquery implementation. – frenchie Commented Jun 30, 2013 at 14:53
  • 1 I fully agree the rationale not to use jQuery, rock on! What browsers do you have to support? Some of these answers are great but in practice treat a lot of IE5 and IE6 edge cases where most sites only support IE8+ today. – Benjamin Gruenbaum Commented Jun 30, 2013 at 15:17
  • 1 Bother because performance is important? – heytools Commented Jun 30, 2013 at 15:46
  • Hi guys! As mentioned by @heytools very correctly. Performance is the key to this template that is why I want to keep the size to minimal. Thanks for going through my question. – Vikram Rao Commented Jun 30, 2013 at 15:54
 |  Show 1 more ment

2 Answers 2

Reset to default 7

from http://www.tutorialspoint./ajax/ , using plain XHR (XmlHttpRequest)

function loadPage() {    
    var ajaxRequest;  

    try{
       // Opera 8.0+, Firefox, Safari
       ajaxRequest = new XMLHttpRequest();
     }catch (e){
       // Internet Explorer Browsers
       try{
          ajaxRequest = new ActiveXObject("Msxml2.XMLHTTP");
       }catch (e) {
          try{
              ajaxRequest = new ActiveXObject("Microsoft.XMLHTTP");
          }catch (e){
              // Something went wrong
              alert("Your browser broke!");
              return false;
          }
       }
     }

     ajaxRequest.onreadystatechange = function(){
       if(ajaxRequest.readyState == 4){
          var ajaxDisplay = document.getElementById('ajaxDiv');
          ajaxDisplay.innerHTML = ajaxRequest.responseText;
       }
     }


     ajaxRequest.open("GET", "ajax-example.php", true);
     ajaxRequest.send(null); 
}

loadPage();

Try this:

window.onload = function(){
aside = document.getElementById("aside");
aside.innerHTML="<img src='loadingImage.gif'>";
if(XMLHttpRequest) var x = new XMLHttpRequest();
else var x = new ActiveXObject("Microsoft.XMLHTTP");
x.open("GET", "other_content_1.php", true);
x.send();
x.onreadystatechange = function(){
    if(x.readyState == 4){
        if(x.status == 200) aside.innerHTML = x.responseText;
        else aside.innerHTML = "Error loading document";
        }
    }
}

And it is cross browser patible, you never need the extra 32KB just to make a simple function supported cross browser.

发布评论

评论列表(0)

  1. 暂无评论