小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

JQuery以JSON方式提交數(shù)據(jù)到服務(wù)端

 一本正經(jīng)地胡鬧 2019-05-27

  JQuery將Ajax數(shù)據(jù)請求進(jìn)行了封裝,從而使得該操作實(shí)現(xiàn)起來容易許多。以往我們要寫很多的代碼來實(shí)現(xiàn)該功能,現(xiàn)在只需要調(diào)用$.ajax()方法,并指明請求的方式、地址、數(shù)據(jù)類型,以及回調(diào)方法等。下面的代碼演示了如何將客戶端表單數(shù)據(jù)封裝成JSON格式,然后通過JQuery的Ajax請求將數(shù)據(jù)發(fā)送到服務(wù)端,并最終將數(shù)據(jù)存儲到數(shù)據(jù)庫中。服務(wù)端定義為一個.ashx文件,事實(shí)上你可以將服務(wù)端定義為任何能接收并處理客戶端數(shù)據(jù)的類型,如Web Service,ASP.NET Page,Handler等。

  首先,在客戶端,通過JavaScript腳本將頁面表單數(shù)據(jù)封裝成JSON格式。GetJsonData()函數(shù)完成了這一功能。然后我們通過$.ajax()方法將數(shù)據(jù)發(fā)送到服務(wù)端的RequestData.ashx。其中用到了JSON.stringify()方法,它可以將客戶端發(fā)送的JSON數(shù)據(jù)對象進(jìn)行序列化操作,詳細(xì)的內(nèi)容可以看這里https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify

復(fù)制代碼
$("#btnSend").click(function() {
    $("#request-process-patent").html("正在提交數(shù)據(jù),請勿關(guān)閉當(dāng)前窗口...");
    $.ajax({
        type: "POST",
        url: "RequestData.ashx",
        contentType: "application/json; charset=utf-8",
        data: JSON.stringify(GetJsonData()),
        dataType: "json",
        success: function (message) {
            if (message > 0) {
                alert("請求已提交!我們會盡快與您取得聯(lián)系");
            }
        },
        error: function (message) {
            $("#request-process-patent").html("提交數(shù)據(jù)失??!");
        }
    });
});

function GetJsonData() {
    var json = {
        "classid": 2,
        "name": $("#tb_name").val(),
        "zlclass": "測試類型1,測試類型2,測試類型3",
        "pname": $("#tb_contact_people").val(),
        "tel": $("#tb_contact_phone").val()
    };
    return json;
}
復(fù)制代碼

  再來看看服務(wù)端的代碼,RequestData.ashx.

復(fù)制代碼
[Serializable]
public class RequestDataJSON
{
    public int classid { get; set; }
    public string name { get; set; }
    public string zlclass { get; set; }
    public string pname { get; set; }
    public string tel { get; set; }
}

/// <summary>
/// Summary description for RequestData
/// </summary>
public class RequestData : IHttpHandler
{
    public void ProcessRequest(HttpContext context)
    {
        int num = 0;
        context.Response.ContentType = "application/json";
        var data = context.Request;
        var sr = new StreamReader(data.InputStream);
        var stream = sr.ReadToEnd();
        var javaScriptSerializer = new JavaScriptSerializer();
        var PostedData = javaScriptSerializer.Deserialize<RequestDataJSON>(stream);

        tb_query obj = new tb_query();
        obj.classid = PostedData.classid;
        obj.name = PostedData.name;
        obj.zlclass = PostedData.zlclass;
        obj.pname = PostedData.pname;
        obj.tel = PostedData.tel;
        obj.ip = context.Request.UserHostAddress.ToString();
        obj.posttime = DateTime.Now.ToString();

        try
        {
            using (var ctx = new dbEntities())
            {
                ctx.tb_query.AddObject(obj);
                num = ctx.SaveChanges();
            }
        }
        catch (Exception msg)
        {
            context.Response.Write(msg.Message);
        }

        context.Response.ContentType = "text/plain";
        context.Response.Write(num);
    }

    public bool IsReusable
    {
        get
        {
            return false;
        }
    }
}
復(fù)制代碼

  定義一個帶有Serializable特征屬性的類RequestDataJSON用來將客戶端數(shù)據(jù)進(jìn)行反序列化,從而獲取到數(shù)據(jù)并存入數(shù)據(jù)庫。上述代碼中使用了EntityFramework,從而使得數(shù)據(jù)庫的交互代碼變得很簡潔。返回結(jié)果有兩種,對應(yīng)ajax中的回調(diào)函數(shù)success()和error()。在success()回調(diào)函數(shù)中,如果返回結(jié)果的值大于0,則表示通過EntityFramework添加到數(shù)據(jù)庫中的記錄數(shù);在error()回調(diào)函數(shù)中,返回結(jié)果則顯示了失敗的具體信息。

  RequestData類繼承了IHttpHandler接口,表明它是以同步的方式處理客戶端請求。當(dāng)然,你也可以將其改為繼承IHttpAsyncHandler接口來處理異步請求,代碼接口大同小異。

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多