I have implemented an Ajax request on my website, and I am calling the endpoint from a webpage. It always returns 200 OK, but jQuery executes the error event.
I tried a lot of things, but I could not figure out the problem. I am adding my code below:
jQuery Code
var row = "1";
var json = "{'TwitterId':'" + row + "'}";
$.ajax({
type: 'POST',
url: 'Jqueryoperation.aspx?Operation=DeleteRow',
contentType: 'application/json; charset=utf-8',
data: json,
dataType: 'json',
cache: false,
success: AjaxSucceeded,
error: AjaxFailed
});
function AjaxSucceeded(result) {
alert("hello");
alert(result.d);
}
function AjaxFailed(result) {
alert("hello1");
alert(result.status + ' ' + result.statusText);
}
C# code for JqueryOpeartion.aspx
protected void Page_Load(object sender, EventArgs e) {
test();
}
private void test() {
Response.Write("<script language='javascript'>alert('Record Deleted');</script>");
}
I need the ("Record deleted") string after successful deletion. I am able to delete the content, but I am not getting this message. Is this correct or am I doing anything wrong? What is the correct way to solve this issue?
jQuery.ajaxattempts to convert the response body based on the specifieddataTypeparameter or theContent-Typeheader sent by the server. If the conversion fails (e.g. if the JSON/XML is invalid), the error callback is fired.Your AJAX code contains:
In this case jQuery:
Your server-side code returns HTML snippet with
200 OKstatus. jQuery was expecting valid JSON and therefore fires the error callback complaining aboutparseerror.The solution is to remove the
dataTypeparameter from your jQuery code and make the server-side code return:But I would rather suggest returning a JSON response and display the message inside the success callback: