一种开发模式:ajax + ashx + UserControl
一、ajax+ashx模式的缺点
二、问题分析与改进(反射)
- public void ProcessRequest(HttpContext context)
- {
- // 1、解析请求参数,此处忽略
- // 2、以下为具体处理方式
- string returnString = string.Empty;
- string methodName = context.Request.Form["methodName"];
- switch(methodName)
- case "GetData":
- returnString = GetData();
- break;
- case "InsertNewRow"
- returnString = InsertNewRow();
- break;
- .....等等多个case分支
- default:
- break;
- // 3、向客户端返回结果
- context.Response.Write(returnString);
- }
- public void ProcessRequest(HttpContext context)
- {
- // 1、解析请求参数,此处忽略其他参数的解析,仅获取方法名
- string methodName = context.Request.Form["Action"];
- // 2、以下为反射的具体处理方式
- Type type = this.GetType();
- Object[] params = new Objece[]; //方法参数,我们统一将context作为参数,以为用户数据都封装在其中
- MethodInfo method = type.GetMethod(methodName);
- string returnString = (string)method.Invoke(this,params);
- // 3、向客户端返回结果
- context.Response.Write(returnString);
- }
public String GetRequest(HttpContext context, String paramName)
{
if (context.Request[paramName] != null)
{
return context.Request[paramName].ToString();
}
return "";
}
- /// <summary>
- /// UserHandler 的摘要说明
- /// </summary>
- public class UserHandler : BaseHandler
- {
- /// <summary>
- /// 用户登录处理
- /// </summary>
- /// <param name="context"></param>
- /// <returns></returns>
- public String Login(HttpContext context)
- {
- String strAccount = "";
- String strPassword = "";
- String strRet;
- try
- {
- //获取页面传值
- strAccount = GetRequest(context, "Account");
- strPassword = GetRequest(context, "Password");
- if (strAccount != "" && strPassword != "")
- {
- //简单起见,仅返回传递过来的用户账号与密码
- //在实际应用中利用传递过来的参数值调用业务逻辑层的方法来完成客户端的请求
- strRet = String.Format("账号:{0},密码:{1}", strAccount, strPassword);
- }
- else
- {
- //返回提示信息
- strRet = "未能正确获取参数!";
- }
- return strRet;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- }
- }
- <script type="text/javascript">
- $(document).ready(function () {
- $("#btnLogin").click(function () {
- var account;
- var password;
- account = $("#txtUserName").val();
- password = $("#txtPassword").val();
- $.ajax({
- type: "POST",
- async: true,
- url: "Handler/UserHandler.ashx",
- dataType: "text",
- data: { Action: "Login", Account: account, Password: password },
- success: function (data) {
- alert(data);
- },
- error: function (xhr) {
- alert(xhr.statusText);
- return false;
- }
- });
- });
- });
- </script>
三、ajax请求中表单数据的封装
四、利用UserControl进行html输出
总结:
2、会员管理、帐户中心、购物车、后台管理等操作界面可以使用AJAX,以提高用户体验和UI交互。
3、网站前台展示的页面,如新闻内容、商品介绍、帮助、文档类页面,不要使用AJAX,以SEO为主。
4、当我们认清楚AJAX什么时候该用,什么时候不该用,一个网站的SEO与AJAX技术结合就变得很简单了。
一种开发模式:ajax + ashx + UserControl的更多相关文章
- ASP.Net的两种开发模式
一.ASP.Net的两种开发模式 1.1 ASP.Net WebForm的开发模式 (1)处理流程 在传统的WebForm模式下,我们请求一个例如http://www.aspnetmvc.com/bl ...
- java web学习总结(二十九) -------------------JavaBean的两种开发模式
SUN公司推出JSP技术后,同时也推荐了两种web应用程序的开发模式,一种是JSP+JavaBean模式,一种是Servlet+JSP+JavaBean模式. 一.JSP+JavaBean开发模式 1 ...
- javaweb学习总结(二十一)——JavaWeb的两种开发模式
SUN公司推出JSP技术后,同时也推荐了两种web应用程序的开发模式,一种是JSP+JavaBean模式,一种是Servlet+JSP+JavaBean模式. 一.JSP+JavaBean开发模式 1 ...
- 《ASP.NET MVC4 WEB编程》学习笔记------Entity Framework的Database First、Model First和Code Only三种开发模式
作者:张博出处:http://yilin.cnblogs.com Entity Framework支持Database First.Model First和Code Only三种开发模式,各模式的开发 ...
- EF的四种开发模式
EF提供了四种开发模式,具体如下:(转载)Code First(New DataBase) :在代码中定义类和映射关系并通过model生成数据库,使用迁移技术更新数据库.Code First(Exis ...
- APP的三种开发模式
转载于http://pleasureswx123.github.io/2014/09/15/APP%E7%9A%84%E4%B8%89%E7%A7%8D%E5%BC%80%E5%8F%91%E6%A8 ...
- 咸鱼入门到放弃10--javaweb的两种开发模式
(本篇是之前方法的综合使用,新东西不多,其中也涉及三层架构的问题.此处直接引用了大佬blog:https://www.cnblogs.com/xdp-gacl/p/3908610.html) SUN公 ...
- JavaWeb学习 (二十)————JavaWeb的两种开发模式
一.JSP+JavaBean开发模式 1.1.jsp+javabean开发模式架构 jsp+javabean开发模式的架构图如下图(图1-1)所示
- javaweb(二十一)——JavaWeb的两种开发模式
一.JSP+JavaBean开发模式 1.1.jsp+javabean开发模式架构 jsp+javabean开发模式的架构图如下图(图1-1)所示
- EntityFramework 学习 一 三种开发模式
Entity Framework支持3种不同的开发方法 1.Code First 2.Model First 3.Database First Code First 使用Code First开发模式, ...
随机推荐
- 运用php做投票题,例题
要求大概是这样的,有一个题目,题目下面是复选框,要求点完复选框提交后会变成进度条,各选项的进度条百分比,和投票数量 首先还是要在数据库建两张表,如下: 要完成这个题目,需要建两个页面 <!DOC ...
- .NET Core的日志[5]:利用TraceSource写日志
从微软推出第一个版本的.NET Framework的时候,就在“System.Diagnostics”命名空间中提供了Debug和Trace两个类帮助我们完成针对调试和跟踪信息的日志记录.在.NET ...
- 深入理解CSS六种颜色模式
前面的话 赏心悦目的颜色搭配让人感到舒服,修改元素颜色的功能让人趋之若鹜.但颜色规划不当,会让网站用户无所适从.颜色从<font color="">发展至今,保留了很多 ...
- 【手把手】JavaWeb 入门级项目实战 -- 文章发布系统 (第十二节)
好的,那么在上一节中呢,评论功能的后台已经写好了,这一节,先把这部分后台代码和前台对接一下. 1.评论功能实现 我们修改一下保存评论按钮的点击事件,用jQuery的方式获取文本框中的值,然后通过aja ...
- PAT练习题目录
点题号就能查看题解了,另外代码也放在了开源中国码云上: 甲级:代码集合:https://git.oschina.net/firstmiki/PAT-Advanced-Level-Practise 10 ...
- Kotlin类:功能更强、而更简洁(KAD 03)
作者:Antonio Leiva 时间:Dec 7, 2016 原文链接:http://antonioleiva.com/classes-kotlin/ Kotlin类尽可能简单,这样用较少的代码完成 ...
- 换个角度看微信小程序[推荐]
去年参加几次技术沙龙时,我注意到一个有意思的现象:与之前大家统一接受的换名片不同,有些人并不愿意被添加微信好友--"不好意思,不熟的人不加微信". 这个现象之所以有意思,是因为名片 ...
- 运用Mono.Cecil 反射读取.NET程序集元数据
CLR自带的反射机智和API可以很轻松的读取.NET程序集信息,但是不能对程序集进行修改.CLR提供的是只读的API,但是开源项目Mono.Cecil不仅仅可以读取.NET程序集的元数据,还可以进行修 ...
- 【AI开发第一步】微软认知服务API应用
目录 介绍 API分类 使用‘视觉’API完成的Demo 点击直接看干货 介绍 从3月份Google家的阿尔法狗打败韩国围棋冠军选手李世石,到之后微软Build2016大会宣布的“智能机器人”战略.种 ...
- JavaScript面向对象
理解对象 对象这个词如雷贯耳,同样出名的一句话:XXX语言中一切皆为对象! 对象究竟是什么?什么叫面向对象编程? 对象(object),台湾译作物件,是面向对象(Object Oriented)中的术 ...