【发布时间】:2013-10-24 02:11:53
【问题描述】:
我收到以下错误:jquery ajax readystate 0 responsetext status 0 statustext error 给它时:url(http://www.tutorialspoint.com/prototype/prototype_ajax_response.htm),但是当我在我的本地主机上给它url(localhost:""/embparse_page) 时它工作正常。
我尝试使用在 Google 搜索中找到的标题,并且我也使用了 beforeSend:"",但它仍然无法正常工作。
我认为主要问题是:XMLHttpRequest cannot load http://www.tutorialspoint.com/prototype/prototype_ajax_response.htm. Origin "local server" is not allowed by Access-Control-Allow-Origin. 但我不明白。
谁能给我解释一下这个问题,因为我对此很陌生。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns:ng="http://angularjs.org">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<meta Access-Control-Allow-Origin="*" />
<title>Page Parsing</title>
<script type="text/javascript" src="/js/jquery-1.9.1.min.js"></script>
<script>
getit=function(){
jQuery.support.cors = true;
$.ajax({
type:"GET",
url:"http://www.tutorialspoint.com/prototype/prototype_ajax_response.htm",
dataType:"html",
crossDomain:true,
beforeSend: function(xhr) {
xhr.overrideMimeType('text/plain;charset=UTF-8');
},
success:function(XMLHttpRequest,jqXHR ,data) {
//alert(data.title);
var starttitl=data.lastIndexOf('<title>');
var endtitl=data.lastIndexOf('</title>');
var title1=data.substring(starttitl+7,endtitl);
alert(title1);
},
error:function(errorStatus,xhr) {
alert("Error"+JSON.stringify(errorStatus));
}
});
}
</script>
</head>
<body>
<div id="siteloader">
<input type="button" onclick="getit()" />
</div>
</body>
</html>
【问题讨论】:
-
一个提示:不要使用警报,因为它是最烦人的调试方式。尝试
console.log并在 Chrome 中按 F12 或在 Firefox 中按 control + shift + k 打开控制台。你有很多工具可以使用,比如设置断点和检查请求及其请求和响应标头。 -
感谢先生的建议
-
这篇文章中评分最高的答案非常深入:stackoverflow.com/questions/15005500/…
-
@HMR,没有警报,如果您在 iOS 设备上进行测试并且没有 Mac 进行任何远程调试,您有什么建议?
标签: javascript jquery ajax