asp.net ajax傳遞Json給aspx.cs后台 webmethod方法傳遞json


1、提取一個向后台寫入數據的方法

            ///向后台cs頁面請求數據的方法
            function myPost(url,data,func) {
                $.ajax({
                    type: "post", //要用post方式  
                    data:data,
                    url: url,//"Demo.aspx/SayHello",//方法所在頁面和方法名
                    contentType: "application/json; charset=utf-8",
                    dataType: "json",
                    success: function (data) {
                        func(1,data.d);
                    },
                    error: function (err) {
                        func(-1,err);
                    }
                });
            }

2.1、沒有參數的傳遞到后台的寫法

            myPost("orgList.aspx/GetOrgList","{}", function (isSuccess, data) {
                    if (isSuccess < 0) { layer.msg(data); return; }
                    if (data && data.length > 0) {
                        zTreeNodes = eval('(' + data + ')');
                        zTreeObj = $.fn.zTree.init($("#tree"), setting, zTreeNodes);
                    }
                });    

2.2帶參數的寫法

              myPost("orgList.aspx/GetModel","{ID:"+treeNode.id+"}", function (isSuccess, data) {
                    if (isSuccess < 0) { layer.msg(data); return; }
                    if (data && data.length > 0) {
                        var model = eval('(' + data + ')');
                        for (var key in model) {
                            vue.model[key] = model[key];
                        }
                    }
                });    

2.3傳遞json的寫法

                var model = String.toSerialize(vue.model);//.replace(/\"/g,"'");  
                myPost("orgList.aspx/Save","{value: '"+model+"'}", function (isSuccess, data) {//當傳遞的是對象的時候,一定要保證將對象轉換為字符串
                    if (isSuccess < 0) { layer.msg(data); return; }
                    if (data == 1) {
                        //重新加載控件
                        GetPowerTree();
                        clearData();
                        layer.msg("保存成功!");
                    }
                    else if (data == -1) {
                        layer.msg("保存失敗!");
                    }
                    else if (data == -2) {
                        layer.msg("此機構已存在!");
                    }
                });

3.1 無參數后台接收方法

        [WebMethod]
        public static string GetOrgList()
        {
            DataTable dt = bll.GetList("1=1").Tables[0];
            return JsonHelper.DataTableToJSON(dt);
        }

3.2帶參數的后台接收方法

       [WebMethod]
        public static string GetModel(long ID)
        {
            Model.Org_Orginfo model = bll.GetModel(ID);
            return JsonHelper.ObjectToJSON(model);
        }

3.3傳遞json的后台接收方法

        [WebMethod]
        public static string Save(string value)
        {
            bool succ = false;
            Model.Org_Orginfo model = JsonHelper.JSONToObject<Model.Org_Orginfo>(value);
            if (model.id < 0)
            {
                if (bll.Exists($"orgName='{model.orgName}'")) return "-2";
                model.Createtime = DateTime.Now;
                model.CreateUser = 1;//創建人-------------------------------------
                succ = bll.Add(model);
                return succ ? "1" : "-1";
            }
            else
            {
                if (bll.Exists($"orgName='{model.orgName}' and id={model.id.ToString()}")) return "-2";
                succ = bll.Update(model);
                return succ ? "1" : "-1";
            }
        }

參考:http://www.cnblogs.com/huanbia/archive/2013/03/03/2941293.html

           https://blog.csdn.net/naruto517308294/article/details/49097493

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM