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

第一种:WebMethod (静态方法)

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

第二种:映射请求方法

        /// <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也会输出
}
}

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

   public class TestController : System.Web.Mvc.Controller
{
public string GetText()
{ var str =Request["value"] + "";
return str;
}
}

前端代码:

<%@ 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 onclick='GetMsg()'>
测试WebMethod</button>
<button onclick='GetMsg1()'>
测试</button>
<input id="test" type="button" value="contrller" onclick="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请求后台。。。的更多相关文章

  1. C# 动态创建SQL数据库(二) 在.net core web项目中生成二维码 后台Post/Get 请求接口 方式 WebForm 页面ajax 请求后台页面 方法 实现输入框小数多 自动进位展示,编辑时实际值不变 快速掌握Gif动态图实现代码 C#处理和对接HTTP接口请求

    C# 动态创建SQL数据库(二) 使用Entity Framework  创建数据库与表 前面文章有说到使用SQL语句动态创建数据库与数据表,这次直接使用Entriy Framwork 的ORM对象关 ...

  2. ajax请求后台有时走有时不走

    ajax请求后台有时走有时不走   ajax请求后台有时走有时不走,是因为没有将请求设置为同步方式,async:false,(默认为true即异步).如果不想使用缓存可以将cache:false,例如 ...

  3. 前台返回json数据的常用方式+常用的AJAX请求后台数据方式

    我个人开发常用的如下所示: 之所以像下面这样下,一是前台Ajax,二是为安卓提供接口数据 现在常用的是返回JSON数据,XML的时代一去不复返 JSON相对于XML要轻量级的多 对JSON不是十分熟悉 ...

  4. JS 操作 HTML 和 AJAX 请求后台数据

    为某个元素插入值,添加属性,添加子元素 <div class="col-sm-6"> <select class="form-control" ...

  5. jquery中ajax请求后台数据成功后既不执行success也不执行error解决方法

    jquery中ajax请求后台数据成功后既不执行success也不执行error,此外系统报错:Uncaught SyntaxError: Unexpected identifier at Objec ...

  6. Ajax请求后台数据

    一.前期准备 安装好XAMPP软件,并运行起来.本文代码是基于XAMPP开发环境,XAMPP是完全免费且易于安装的Apache发行版,其中包含MariaDB.PHP和Perl.XAMPP开放源码包的设 ...

  7. 解决.NET Core Ajax请求后台传送参数过大请求失败问题

    解决.NET Core Ajax请求后台传送参数过大请求失败问题 今天在项目上遇到一个坑, 在.Net Core中通过ajax向mvc的controller传递对象时,控制器(controller)的 ...

  8. ajax请求后台,有时收不到返回值的解决办法

    昨天下午做项目遇到一个问题,贴出来方便以后翻阅,也给大家个参考. 问题: 具体做的是个文件导入的功能,导入的功能是成功了,但是界面一直得不到返回值,排查了一下午,调试的时候是可以有返回的,但是关掉浏览 ...

  9. 解决Ajax请求后台Servlet接口拿不到JSON数据问题

    前端Ajax请求代码如下: window.onload=function() { var url='http://127.0.0.1:8080/testpj/ErrorlogServlet'; $.a ...

随机推荐

  1. 跟着alex学习了格式化输出,最大的感受就是编程这个事,一定要自己动手去做,才能学会。看会和自己会做完全是两码事

    学习了三天,现在学到格式化输出.看视频教程,alex和那个美女学员打情骂俏,真是羡慕啊. 教程看懂很容易,完全会了. 可是上手编程马上歇菜. 就这么几行的代码,我遇到了n多错误 首先是中文输入的错误, ...

  2. ES6学习历程(变量的解构赋值)

    一.数组的解构赋值 1.举几个例子足以理解 let [a, b, c] = [1, 2, 3]; a:1;  b:2;  c:3; let [x, , y] = [1, 2, 3];  x:1   y ...

  3. 第二节:numpy之数组切片、数据类型转换、随机数组

  4. 《你说对就队》第八次团队作业:Alpha冲刺 第五天

    <你说对就队>第八次团队作业:Alpha冲刺 第五天 项目 内容 这个作业属于哪个课程 [教师博客主页链接] 这个作业的要求在哪里 [作业链接地址] 团队名称 <你说对就队> ...

  5. ssm 数据库连接池配置

    1.工程引入druid-1.1.2.jar包2.修改spring-common.xml文件 <!-- 1. 数据源 : DruidDataSource--> <bean id=&qu ...

  6. bupt summer training for 16 #2 ——计算几何

    https://vjudge.net/contest/171368#overview A.一个签到题,用叉积来判断一个点在一条线的哪个方向 可以二分,数据范围允许暴力 #include <cst ...

  7. [Bzoj4196] [NOI2015] 软件包管理器 [树链剖分,线段树]

    题解摘要:树链剖分后用线段树区间查询修改,对于安装软件,将改点到根的路径全部变为1,对于卸载软件,将子树清空.注意边界,编号是从0开始的,容易漏掉树根. 第一次写树剖- #include <io ...

  8. [USACO16OPEN]关闭农场Closing the Farm(洛谷 3144)

    题目描述 Farmer John and his cows are planning to leave town for a long vacation, and so FJ wants to tem ...

  9. 使用外部LDAP用户认证后,DJANGO用户如何作登陆的操作?

    公司的要求,使用公司的UM帐号验证密码,然后,在DJANGO里登陆. 因为没有authenticate函数,只有login函数,所以不能简单的使用用户来login,而需要加一个backend参数... ...

  10. PDF在线预览-pdfjs使用

    请参考我的开源: https://github.com/wuyechun2018/itools/blob/master/src/main/webapp/WEB-INF/views/pdf/index. ...