Skip to content Skip to sidebar Skip to footer

Jquery Ajax Success Result Is Null

I am doing an ajax call using jquery to get data in json format. the success callback function is called but the data is empty. $(document).ready(function () { $.ajax({

Solution 1:

You're being blocked by the same-origin policy which prevents cross-domain XMLHttpRequests. Since you need to set headers to get JSON back from a .Net web service like this, you're in a tough spot, you just can't make that kind of request from a browser, not from a different domain.

Fiddler may be showing the content, but the browser isn't going to let the page see it, for security reasons it'll always be null. The one way around this is JSONP, but unfortunately it doesn't look like that service is setup to support it.

Solution 2:

I believe you can make your calls generic (reason as marduk indicates)

To handle this, and to make calls generic (works with data and data.d), I use the following in my ajax calls (with my asp.net stuff) so that it works with older as well as newer services:

dataFilter: function(data)
    {
        var msg;
        if (typeof (JSON) !== 'undefined' &&
        typeof (JSON.parse) === 'function')
            msg = JSON.parse(data);
        else
            msg = eval('(' + data + ')');
        if (msg.hasOwnProperty('d'))
            return msg.d;
        elsereturn msg;
    },

EDIT: IF it is truly null AND NOT "undefined" then the cross domain issue might be in play here.

Solution 3:

try this

if (data.d == null) {
    alert("data.d is null");
    return;
}

since your return datatype is json, the data is in the data, "d", variable in the response object.

Post a Comment for "Jquery Ajax Success Result Is Null"