C#WebForm里面aspx,ajax请求后台。。。

C#WebForm里面aspx,ajax请求后台。。。

  虽然WebForm里面有那些基本控件,后台CS里面也有许许多多的控件的方法。但是不见得有些标签不需要进行后台的访问,下面介绍一下三种aspx中访问后台的方式。。

第一种:WebMethod (静态方法)

C#WebForm里面aspx,ajax请求后台。。。

     //通过WebMethod的静态方法,访问自己cs后面的方法
     [WebMethod]
        public static string GetMsgByWeb()
        {           
            return  "Hello Word";
        }

C#WebForm里面aspx,ajax请求后台。。。

第二种:映射请求方法

C#WebForm里面aspx,ajax请求后台。。。

        /// <summary>
        /// 通过映射访问自己cs后面方法
        /// </summary>
        /// <param name="page"></param>
        /// <param name="method"></param>
        /// <returns></returns>
        public static void GetJsonByPage(Page page,string method="act")
        { 
            var m_method = page.Request[method];
            if (m_method != null)
            {
                try
                {
                    var res = page.GetType().GetMethod(m_method, BindingFlags.Public | BindingFlags.Static | BindingFlags.Instance).Invoke(page,null);                 
                    if (res != null)
                        page.Response.Write(res);
                }
                catch (Exception ex)
                {
                    page.Response.Write(JsonConvert.SerializeObject(ex));                    
                }
                page.Response.End();//将当前所有缓冲输出到客户端,停止该页的执行,否则页面HTML也会输出
            }
        }

C#WebForm里面aspx,ajax请求后台。。。

第三种:MVC模式请求控制器

C#WebForm里面aspx,ajax请求后台。。。

   public class TestController : System.Web.Mvc.Controller
    {
        public string GetText()
        {

            var str =Request["value"] + "";
            return str;           
        }
    }

C#WebForm里面aspx,ajax请求后台。。。

 

 

前端代码:

C#WebForm里面aspx,ajax请求后台。。。

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="testWebMethod.aspx.cs"
    Inherits="StudyProgram.Pages.testWebMethod" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <script src="../Scripts/JQuery-1-10-2.js" type="text/javascript"></script>
    <style>
        
    </style>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <button οnclick='GetMsg()'>
            测试WebMethod</button>
        <button οnclick='GetMsg1()'>
            测试</button>
        <input id="test" type="button" value="contrller" οnclick="fnGetMsg(this)" />
    </div>
    </form>
    <script>
        $(function () {
            //GetMsg();
        });

        //请求后台静态方法
        function GetMsg() {
            $.ajax({ //调用的静态方法,所以下面必须参数按照下面来
                url: 'testWebMethod.aspx/GetMsgByWeb',
                type: 'post',
                contentType: "application/json",
                dataType: 'json',
                data: "{}", //必须的,为空的话也必须是json字符串
                success: function (data) {//这边返回的是个对象
                    console.log(data);
                    if (data != null)
                        alert(data.d);
                }
            });
        }

        //通过后台映射方法请求数据
        function GetMsg1() {
            $.ajax({ //调用的静态方法,所以下面必须参数按照下面来
                url: '?method=GetMsgByWeb1',
                type: 'post',
                data: { id: 'huage' }, 
                dataType: 'text',
                success: function (data) {
                    console.log(data);
                    if (data != "")
                        alert(data);
                }
            });
        }
        
        //通过请求控制器得到结果
        function fnGetMsg(btn) {
            var value = $(btn).val();
//            $.post("../Controllers/Controller/Test", function (res) {
//                if (!res)
//                    alert(res);
            //            });

            $.ajax({ //调用的静态方法,所以下面必须参数按照下面来
                url: "../../Test/GetText",
                type: 'post',
                data: { value: value },
                dataType: 'text',
                success: function (data) {//这边返回的是个对象
                    console.log(data);
                    if (data)
                        alert(data); 
                }
            });
        }
    </script>
</body>
</html>

C#WebForm里面aspx,ajax请求后台。。。

 

本文只是记录学习心得,如果有误请提示博主加以修正。。。 谢谢您那么帅气,还能看完小主的文言文!

上一篇:.net 4.0的webform服务器端控件渲染的改变


下一篇:多图片上传WebForm