1

我知道有一种 JQuery 方法可以做到这一点,但这不是我现在需要的。

我有以下将页面内容拉入 div 的 javascript,但是我不想要整个页面,只需要该页面中 DIV 的内容:

function ahah(url, target) {
document.getElementById(target).innerHTML ='<img src="ajax-loader.gif"/>';
 if (window.XMLHttpRequest) {
 req = new XMLHttpRequest();
} else if (window.ActiveXObject) {
 req = new ActiveXObject("Microsoft.XMLHTTP");
}
if (req != undefined) {
req.onreadystatechange = function() {ahahDone(url, target);};
req.open("GET", url, true);
req.send("");
}
}  

function ahahDone(url, target) {
  if (req.readyState == 4) { // only if req is "loaded"
    if (req.status == 200) { // only if "OK"
      document.getElementById(target).innerHTML = req.responseText;
    } else {
      document.getElementById(target).innerHTML=" Error:\n"+ req.status + "\n" +req.statusText;
    }
  }
}

function load(name, div) {
ahah(name,div);
return false;
}

然后我这样称呼它:

<a href="page.php" onclick="load('page.php','ajaxcontent');return false;" class="slide_more">LOAD</a>

应该在哪里指定我想从 page.php 加载的选择器?

4

1 回答 1

2

通常在 AJAX 应用程序中,为了获取 HTML 片段,服务器是返回片段的人,而不是在客户端选择它。例如,请参阅第 4 节的这个简单示例。很酷的 AJAX 示例。下面提供了来自网站的代码供您参考:

<?php
function validate($name) {
  if($name == '') {
    return '';
  }

  if(strlen($name) < 3) {
    return "<span id=\"warn\">Username too short</span>\n";
  }

  switch($name) {
    case 'bob':
    case 'jim':
    case 'joe':
    case 'carol':
      return "<span id=\"warn\">Username already taken</span>\n";
  }

  return "<span id=\"notice\">Username ok!</span>\n";
}

echo validate(trim($_REQUEST['name']));
?>

请注意,PHP 页面只是返回一个包含<span>唯一而不是完整 html 的 HTML 片段。这是 AJAX 调用的好处之一,您不需要返回整个页面,从而节省带宽成本,因为有效负载更小

于 2011-09-07T15:09:30.453 回答