Reputation: 2393
Jquery
$('#PostComment').click(function () {
var commentTitle = $('#commentTitle').val();
var commentClob = $('#commentClob').val();
var id = $('#topicId').val();
var buttoname = $('#PostComment').val();
var obj;
$.ajax({
type: "post",
url: "../../Handler/Topic.ashx",
data: "commentclob=" + commentClob + "&commenttitle=" +
commentTitle + "&topicId=" + id + "&Button=" + buttoname,
success: function (msg) {
try {
alert(msg);
obj = jQuery.parseJSON(msg);
alert("Correct" + obj.CommentClob);
}
catch (e) {
alert("Incorrect" + e.Description + e.ErrorNumber);
}
}
});
return false;
});
});
Topic.ashx -ProcessRequest method
CommentModel cm = daoobject.populateCommentModel(listcommentsbytopic);
var json= cm.CreateCommentJson();
context.Response.Write(json);
Function definition
public string CreateCommentJson()
{
// serialize the names to JSON
var jss = new JavaScriptSerializer();
var json = jss.Serialize(this);
return json;
}
I am getting output 2 alert boxes
first is
{ "UserId": "1", "ToipicId": "44f94c32-c415-4751-812a-03b775775698", "CommentId": "0f1014a0-08d9-48f7-9a0c-d9d6b3d841b2", "CommentClob": "ilikeit", "CommentTitle": "nice", "DescriptionClob": null, "DateCreated": "/Date(1333233498780)/", "Datemodified": "/Date(-62135596800000)/" }
and second is
Incorrect undefined undefined
Can anyone help.
Upvotes: 4
Views: 3504
Reputation: 10961
Your returned json is malformed. You should not be escaping all of the "
as you are.
Run your json response msg
through http://jsonlint.com and then run this one through it.
{
"UserId": "1",
"ToipicId": "44f94c32-c415-4751-812a-03b775775698",
"CommentId": "0f1014a0-08d9-48f7-9a0c-d9d6b3d841b2",
"CommentClob": "ilikeit",
"CommentTitle": "nice",
"DescriptionClob": null,
"DateCreated": "/Date(1333233498780)/",
"Datemodified": "/Date(-62135596800000)/"
}
Follow on:
In your comments, you state that you are getting the first alert printed out. If you are getting it printed out as you say, then that shows that the data is still in string format and NOT already parsed as json. If it were already parsed as json, you'd be getting an [Object object] message instead of the actual text.
That being said, check out this jsFiddle and this resulting of a Firebug breakpoint.
This essentially shows that the .parseJSON() function will properly parse this new 'json string'. From what you've given us, it tells me that you haven't given us everything. You are doing something (possible typo?, more processing that isn't getting posted?, something!) to that string (if in fact you are getting it as stated) before you parse it with JQuery.
Upvotes: 4
Reputation: 70
I think you are parsing listcommentsbytopic to json twice.
first time here:
CommentModel cm = daoobject.populateCommentModel(listcommentsbytopic);
var json= cm.CreateCommentJson();
context.Response.Write(json);
second time here:
obj = jQuery.parseJSON(msg);
above line is not needed
when you are sending json data from server why are you not using
dataType: 'json'
in below function
$('#PostComment').click(function () {
var commentTitle = $('#commentTitle').val();
var commentClob = $('#commentClob').val();
var id = $('#topicId').val();
var buttoname = $('#PostComment').val();
var obj;
$.ajax({
type: "post",
url: "../../Handler/Topic.ashx",
data: "commentclob=" + commentClob + "&commenttitle=" +
commentTitle + "&topicId=" + id + "&Button=" + buttoname,
dataType: 'json', /// this one expect data in json format
success: function (msg) {
try {
alert(msg);
obj = jQuery.parseJSON(msg);
alert("Correct" + obj.CommentClob);
}
catch (e) {
alert("Incorrect" + e.Description + e.ErrorNumber);
}
}
});
return false;
});
});
Upvotes: 0
Reputation: 69915
Your json is not an array it is a key value pair object.
There is a run time error on this line alert("Correct" + obj[0].CommentClob)
. Change this line to alert("Correct" + obj.CommentClob);
As a side note, in order to get the error message from exception object(e) use e.message
or e.description
and for error number use e.number
. Since JavaScript is case sensitive e.Description
or e.Number
will give you undefined value.
Working demo - http://jsfiddle.net/MuEYt/
Upvotes: 0
Reputation: 196236
Use obj.CommentClob
instead of obj[0].CommentClob
as the json is not an array..
Additionally you can give another option dataType: 'json'
to the .ajax()
call and have jQuery handle the parsing.. (or use $.getJSON()
directly)
Upvotes: 0