我正在尝试在我的项目中实现 jQuery 地址插件。
我正在关注Crawling实现的 Asual 示例(即 hashbangs)。
我的JavaScript:
<script type="text/javascript">
$.address.init(function(event) {
// Initializes plugin support for links
$('a:not([href^=http])').address();
var handler = function(data) {
$('.content').html($('#content', data).html()).parent().show();
$.address.title(/>([^<]*)<\/title/.exec(data)[1]);
};
// Loads the page content and inserts it into the content area
$.ajax({
url: '/index.php?ACT=87&action=shows&_escaped_fragment_=' + encodeURIComponent(event.value),
error: function(XMLHttpRequest, textStatus, errorThrown) {
handler(XMLHttpRequest.responseText);
},
success: function(data, textStatus, XMLHttpRequest) {
handler(data);
},
contentType: 'text/html'
});
});
</script>
$.ajax() 调用正在请求我创建的虚拟 html 页面:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"><html>
<head><title>testing</title>
</head>
<body>
<div id="content">test</div>
</body>
</html>
我正在发送带有text/html
内容类型的这个 HTML 页面。
请求执行成功,处理程序匿名函数正在获取整个页面数据,但$('.content).html()
命令不起作用。当我这样做时alert($('#content', data).html());
,我得到了null
,并且没有任何反应。没有错误,但也没有内容。
在这一点上,我几乎束手无策……有什么建议吗?
编辑:澄清一下,问题不在于请求本身,也不在于 URL,也不是浏览器安全问题。我根本无法从页面上的请求中选择和显示数据。
更糟糕的是,如果我简单地将 $.ajax() url 替换为我知道不存在的页面(即 404 页面)的 url,它会很好地解析并显示我的 404 消息。