我想在不使用服务器或在Chrome浏览器中闲置安全性的情况下发送AJAX请求。
这是我的代码:
if(document.getElementById("showJson")){
document.getElementById("showJson").addEventListener("click", init);
}
function init(){
loadJSON(function (response){
var actual_JSON = JSON.parse(response);
});
}
function loadJSON(callback) {
var xobj = new XMLHttpRequest();
xobj.overrideMimeType("application/json");
xobj.open('GET', 'my_data.json', true); // Replace 'my_data' with the path to your file
xobj.onreadystatechange = function () {
if (xobj.readyState == 4 && xobj.status == "200") {
// Required use of an anonymous callback as .open will NOT return a value but simply returns undefined in asynchronous mode
callback(xobj.responseText);
}
};
xobj.send(null);
console.log(xobj);
}
,这是JSON文件"学生":
[{
"name" : "Mohamed Kamel",
"age" : 24,
"grade" : 100
},{
"name": "hamada",
"age" : 20,
"grade":90
},{
"name" : "ali",
"age" : 23,
"grade" : 80
}]
你不能。
出于安全原因下载文件必须仅通过用户许可完成。
但是为什么要这样做?服务器读取文件并发送内容或发送文件没有区别(性能)。在这两种方式上,服务器都读取文件。
看起来您遇到了'交叉起源'问题。如果要请求的文件在另一个域上,则可能会设置"严格的原始 - 杂交孔"。如果该网站的所有者希望能够与任何人共享JSON文件,他们应该将名称从.json更改为.php并将其添加到其标题中。
header("Access-Control-Allow-Origin: *");