发送AJAX请求以使用纯JavaScript从JSON文件中获取JSON数据



我想在不使用服务器或在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: *");

相关内容

  • 没有找到相关文章

最新更新