本人遇到的問題 :
用getJSON 異步調(diào)用數(shù)據(jù),返回json 數(shù)據(jù)集合,數(shù)據(jù)是反回了 但是 沒有執(zhí)行回調(diào)函數(shù)
正確后的代碼:
js文件
//獲取列表
function getlist() {
var topID = $("#articleid").val();
//var params = "topicID=" + topID;
$.getJSON("http://news." + domian + "/AjaxList.ashx?topicID="+topID+"&format=json&
jsoncallback=?", function (data) {
$("#commentlist").html(data.contentlist);
});
}
一般處理文件
<%@ WebHandler Language="C#" Class="AjaxList" %>
using System;
using System.Web;
using LitJson;
using UCenter.Logic.Members;
using WCms.Entity.Common;
using WCms.Logic.Common;
using Qyn.Studio.Extend;
using Qyn.Studio.Utils;
///
/// 獲取電子優(yōu)惠卷
/// public class AjaxList : IHttpHandler
{
public void Proce***equest(HttpContext context)
{
context.Response.ContentType = "text/plain";
context.Response.AddHeader("P3P", "CP=CAO PSA OUR");
var data = new JsonData();
var contentlist = new StringPlus();
//var ID=UserLogic.GetCookies().ID;
//var userinfo = UserLogic.Data.Where(t => t.ID == ID.GetValueOrDefault()).ToInfo();
var jsoncallback = QynRequest.QS("
jsoncallback");
var cTopicID = QynRequest.QS("topicID").ConvertType(0);
if (cTopicID > 0)
{
var list = WCms.Logic.Common.CommentLogic.Data.Where(t => t.TopicID == cTopicID.ConvertType(0)).Selector(t => new { t.Contents, t.CreateAt, t.CreateName })
.Desc(t => t.CreateAt).ToList(5);
contentlist.AppendLine("
");
contentlist.AppendLine("
網(wǎng)友評論
");
contentlist.AppendLine("");
data["contentlist"] = contentlist.Value;
}
context.Response.Write(
jsoncallback + "
(" +
data.ToJson() + "
)");
}
public bool IsReusable
{
get
{
return false;
}
}
}
劃紅線的部分是重點需要注意的事情
注:format=json 可以不加
jsoncallback 也可以換成 callback
不過一般處理文件里面 也必須要和 js文件里的 jsoncallback 或著 callback 一致。
以上就是這個問題的解決辦法 ,如有問題請留言
網(wǎng)頁題目:jQuerygetJSON處理json數(shù)據(jù)的代碼解決ajax跨域返回json數(shù)據(jù)問題
網(wǎng)頁URL:
http://weahome.cn/article/gdsjpo.html