委托delegate与Dictionary实现action方法调用
大家一定都有这种情况,
1.前台页面信息是通过Ajax请求的方法加载的;
2.或者是通过请求本页面加载的;
3.请求的页面不仅仅是一个Http请求
在 这咱情况下我们一般会加一个action的参数,用于区别是应该调用那个方法
前台的发起我就不多说了,这个大家都知道,关键是后台应该怎么写呢。
通常情况下一般是这样的

?
//取出action的值
string action = context.Request[ "action" ];
if (action == "post1" )
{
//调用第一个Post方法
}
else "post2" )
{
//调用第一个Post方法
}
"post3" )
{
//调用第一个Post方法
}
else
{
//调用在没有找到action对应方法时执行
}

我感觉这种情况是比较多的,其实而可以使用Dictionary与delegate配置的方法来实现会更灵活一些。
意思就是把方法生成一个List形式的,
我一直是这么用的,今天正好看到 同事也是这么写的,所以就拿出来给大家分享一下。因为我发现还有少人在用第一种方式
算是给大家提供一个解决方案吧。
大家看如下代码就明白了

//定义一个委托
private delegate void actionByMain(HttpContext context);
//定义一Key,Value的键值对,大家注意这里把委托放进去了
static Dictionary< ,actionByMain> mainList = new ottom:auto!important; float:none!important; height:auto!important; left:auto!important; line-height:2em!important; margin:0px!important; outline:0px!important; overflow:visible!important; padding:0px!important; position:static!important; right:auto!important; top:auto!important; vertical-align:baseline!important; width:auto!important; font-family:'Courier New',actionByMain>();
public ProcessRequest(HttpContext context)
{
action = .Empty;
( .IsNullOrEmpty(context.Request[ ]))
{
return ;
}
];
//先检查一下有没有这个action
(mainList.ContainsKey(action))
{
mainList[action](context); ;
}
}
//添加action对应方法的列表
static addMainList()
{
mainList.Add( ottom:auto!important; float:none!important; height:auto!important; left:auto!important; line-height:2em!important; margin:0px!important; outline:0px!important; overflow:visible!important; padding:0px!important; position:static!important; right:auto!important; top:auto!important; vertical-align:baseline!important; width:auto!important; font-family:'Courier New', delegate (HttpContext context)
{
context.Response.Write( "成功" );
});
(HttpContext context)
{
);
});
(HttpContext context)
{
;
});
好了大家看看这种方法

原文地址:http://www.sufeinet.com/thread-3102-1-1.html

总结

以上是DEVMAX为你收集整理的委托delegate与Dictionary实现action方法调用全部内容。

如果觉得DEVMAX网站内容还不错,欢迎将DEVMAX网站推荐给好友。

委托delegate与Dictionary实现action方法调用的更多相关文章

  1. ios – 属性类型’id’与从’UIToolbar’警告继承的类型’id’不兼容

    我刚刚安装了xcode5,现在我收到了这个警告.我以前从未见过它.我的应用运行良好,但我讨厌看到一个警告.有谁知道这是什么以及如何解决它?

  2. ios – 使用Swift 3.0附近的蓝牙设备

    )我只是使用函数内置的参数来提及它确实是一个IOBluetoothDevice对象,而且只是要求打印这些信息.最后的说明我希望在Swift中使用IOBluetooth时,我创建的这个Q/A可以帮助其他有需要的人.缺乏任何教程和大量过时的Objective-C代码使得查找此信息非常具有挑战性.我要感谢@RobNapier在一开始就试图找到这个谜题的答案的支持.我还要感谢NotMyName在AppleDeveloper论坛上对我的post的回复.我将在iOS设备中更早地探索这种用法!

  3. ios – 如何使用新的Apple Swift语言发布JSON

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  4. ios – 向UITextField输入右视图UIImageView

    我有一个目标操作,当按下按钮时,我验证UITextFields:我的UITextFields添加到viewDidLoad中的视图,如下所示:如何使右视图UIImageView出现?解决方法你确定你没有丢失UITextField框架吗?你正在设置rightviewmode吗?这是我刚才写的一个例子,似乎工作正常.结果如下:

  5. ios – 从后台线程显示的UIAlertView和没有委托创建EXC_BAD_ACCESS

    解决方法不要从后台线程弄乱UI.在主线程上创建一个方法并调用该方法:

  6. ios – 无法转换为`AnyObject?`?

    .不应该有任何东西可以转换为AnyObject??这是我的主要代码:提前致谢.解决方法AnyObject是所有类符合的协议.要定义只能由类采用的协议,请添加:类到定义:没有这个修改,可以是struct或enum类型,也不能转换为AnyObject.

  7. ios – 如何在Swift中执行委派的基本实现?

    我试图让我的头脑围绕代表团,并将其剥离到一个基本的实现.我想出了这个,但委托函数永远不会被调用.任何人都可以解释一下吗?解决方法Point是在调用callDelegate()之前需要分配委托.要检查委派是否正常工作,可以使用委托初始化DelegatorClass.

  8. ios – 将UIApplicationDelegate方法转换为RxSwift Observables

    得到打印然后我在RxCocoa的_RXDelegateProxy_类中得到以下崩溃:有谁知道问题可能是什么?或者有没有人成功实现过像rx_applicationDidBecomeActive这样的东西?

  9. 【swift_4】swift之代理传值(delegate的用法)

    具体的代码,详见Demo:链接:http://pan.baidu.com/s/1gdkyWE3密码:4mhvrootViewControllersecondViewController

  10. swift 创建第一个UIAlertView 和UIActionSheet

    //创建UIActionSheet//一定要指明类型,不编译不通过funcActionSheet(sender:UITapGestureRecognizer){letactionSheet:UIActionSheet=UIActionSheet(title:"Areyousure?",delegate:self,cancelButtonTitle:"Cancel",destructiveButto

随机推荐

  1. xe-ajax-mock 前端虚拟服务

    最新版本见Github,点击查看历史版本基于XEAjax扩展的Mock虚拟服务插件;对于前后端分离的开发模式,ajax+mock使前端不再依赖后端接口开发效率更高。CDN使用script方式安装,XEAjaxMock会定义为全局变量生产环境请使用xe-ajax-mock.min.js,更小的压缩版本,可以带来更快的速度体验。

  2. vue 使用 xe-ajax

    安装完成后自动挂载在vue实例this.$ajaxCDN安装使用script方式安装,VXEAjax会定义为全局变量生产环境请使用vxe-ajax.min.js,更小的压缩版本,可以带来更快的速度体验。cdnjs获取最新版本点击浏览已发布的所有npm包源码unpkg获取最新版本点击浏览已发布的所有npm包源码AMD安装require.js安装示例ES6Module安装通过Vue.use()来全局安装示例./Home.vue

  3. AJAX POST数据中文乱码解决

    前端使用encodeURI进行编码后台java.net.URLDecoder进行解码编解码工具

  4. Koa2框架利用CORS完成跨域ajax请求

    实现跨域ajax请求的方式有很多,其中一个是利用CORS,而这个方法关键是在服务器端进行配置。本文仅对能够完成正常跨域ajax响应的,最基本的配置进行说明。这样OPTIONS请求就能够通过了。至此为止,相当于仅仅完成了预检,还没发送真正的请求呢。

  5. form提交时,ajax上传文件并更新到&lt;input&gt;中的value字段

  6. ajax的cache作用

    filePath="+escape;},error:{alert;}});解决方案:1.加cache:false2.url加随机数正常代码:网上高人解读:cache的作用就是第一次请求完毕之后,如果再次去请求,可以直接从缓存里面读取而不是再到服务器端读取。

  7. 浅谈ajax上传文件属性contentType = false

    默认值为contentType="application/x-www-form-urlencoded".在默认情况下,内容编码类型满足大多数情况。在这里,我们主要谈谈contentType=false.在使用ajax上传文件时:在其中先封装了一个formData对象,然后使用post方法将文件传给服务器。说到这,我们发现在JQueryajax()方法中我们使contentType=false,这不是冲突了吗?这就是因为当我们在form标签中设置了enctype=“multipart/form-data”,

  8. 909422229_ajaxFileUpload上传文件

    ajaxFileUpload.js很多同名的,因为做出来一个很容易。我上github搜AjaxFileUpload出来很多类似js。ajaxFileUpload是一个异步上传文件的jQuery插件传一个不知道什么版本的上来,以后不用到处找了。语法:$.ajaxFileUploadoptions参数说明:1、url上传处理程序地址。2,fileElementId需要上传的文件域的ID,即的ID。3,secureuri是否启用安全提交,默认为false。4,dataType服务器返回的数据类型。6,error

  9. AJAX-Cache:一款好用的Ajax缓存插件

    原文链接AJAX-Cache是什么Ajax是前端开发必不可少的数据获取手段,在频繁的异步请求业务中,我们往往需要利用“缓存”提升界面响应速度,减少网络资源占用。AJAX-Cache是一款jQuery缓存插件,可以为$.ajax()方法扩展缓存功能。

  10. jsf – Ajax update/render在已渲染属性的组件上不起作用

    我试图ajax更新一个有条件渲染的组件。我可以确保#{user}实际上是可用的。这是怎么引起的,我该如何解决呢?必须始终在ajax可以重新呈现之前呈现组件。Ajax正在使用JavaScriptdocument.getElementById()来查找需要更新的组件。但是如果JSF没有将组件放在第一位,那么JavaScript找不到要更新的内容。解决方案是简单地引用总是渲染的父组件。

返回
顶部