使用Enyo框架的AJAX调用



我正试图使用enyo框架进行ajax调用,但我遇到了一个问题。我收到的错误消息是0。这只是一个0。我确保我到json文件的链接是正确的,我构建了这个jsfiddle来测试它http://jsfiddle.net/mmahon512/CPU8n/2/非常感谢您的帮助。我的主机是GoDaddy,我确保我正确地将json扩展添加到了我的web配置中。json文件的链接是正确的,它返回有效的json。我用jsonint检查过。以下是jsfiddle上的代码:

enyo.kind({ name: "AjaxSample", components: [ { kind: "Button", content: "Fetch Users", ontap: "fetch" }, { name: "repos", content: "Not loaded...", allowHtml: true } ], fetch: function() { var ajax = new enyo.Ajax({ url: "http://atxapps.com/_sites/atxapps.com/dev/jetstream/assets/dataUsers.json" }); ajax.go(); ajax.response(this, "gotResponse"); ajax.error(this, this.gotError); }, gotResponse: function(inSender, inResponse) { var output = ""; for(i = 0; i < inResponse.length; i++) { output += inResponse[i].Id + "
"; } output += Date.now(); this.$.repos.setContent(output); }, gotError: function(inSender, inError) { alert(inError); this.$.repos.setContent(inError + " " + Date.now()); }

});

看起来像是CORS问题。我在控制台中看到以下内容:

请求的资源上不存在"Access Control Allow Origin"标头。Origin fiddle.jshell.net因此不允许访问。

我成功地将其包装为jsonp请求。

http://jsfiddle.net/CPU8n/3/

enyo.kind({
    name: "AjaxSample",
    components: [
        { kind: "Button", content: "Fetch Users", ontap: "fetch" },
        { name: "repos", content: "Not loaded...", allowHtml: true }
    ],
    fetch: function() {
        var ajax = new enyo.JsonpRequest({
            url: "http://jsonpwrapper.com/?urls%5B%5D=http%3A%2F%2Fatxapps.com%2F_sites%2Fatxapps.com%2Fdev%2Fjetstream%2Fassets%2FdataUsers.json"
        });
        ajax.go();
        ajax.response(this, "gotResponse");
        ajax.error(this, this.gotError);
    },
    gotResponse: function(inSender, inResponse) {
        var output = "";
        var body = enyo.json.parse(inResponse[0].body); // jsonpwrapper.com wraps the results in a array with an index for each URL. The actual data is in the body param of that index but it isn't parsed (at least in this example)
        for(i = 0; i < body.length; i++) {
            output += body[i].Id + "<br />";
        }
        output += Date.now();
        this.$.repos.setContent(output);
    },
    gotError: function(inSender, inError) {
        alert(inError);
        this.$.repos.setContent(inError + " " + Date.now());
    }
});

如果您在prod中的同一台服务器上运行此程序,则不会看到错误(因为它不是跨原点的)。如果它在不同的服务器上,您可以转换服务器端以支持jsonp,也可以添加适当的CORS头。

最新更新