如果你没有看我第二天写的内容的,我想你是看不懂的!!!!

好了,废话不多说,怎么才能让我们的代码变得牛逼起来呢?怎么封装我们的代码呢?我们不可能 每个页面都需要那样写吧,那我们来一步一步来封装 我们的代码,变得更牛逼,维护性更高!!!!!

首先我们来分析,我昨天写的代码:

第一步:在界面写入2个隐藏控件,用来存放方法名和参数  (亲们,你们不可能每个页面都去写吧!!!当然不行,那怎么办)

我们是这样实现的,通过jquery在页面每次在页面加载完成后,判断控件是否存在,不存在在就写入,存在就不作任何操作!!

$(function () {
if ($("#hid_fangfa").length < 1) // 判断方法名 的隐藏控件是否存在,不存在就写入隐藏控件
{
$("#form1").children().eq(0).after('<input type="hidden" name="hid_fangfa" id="hid_fangfa" />');
} if ($("#hid_canshu").length < 1) {// 判断参数 的隐藏控件是否存在,不存在就写入隐藏控件
$("#form1").children().eq(0).after('<input type="hidden" name="hid_canshu" id="hid_canshu" />'); } });

 第二步:js写一个方法,只用写一个参数(方法名),就可以动态拼接多个参数,将动态参数拼接完成放入隐藏控件中,然后执行表单提交(感觉js没有学好,好难实现!!!!!)

这里我们要用到arguments 的 动态参数!!!(这里除了 方法名字不用拼接之外的其他参数都要拼接 ,我们这用  ‘|’来拼接的)

function gohoutai(fangfa) {
var canshu = '';
for (var i = 0; i < arguments.length; i++) { //获取所有的参数,除了方法名之外全部需要拼接
if (typeof (arguments[i]) == 'object') //拼接对象只支持 string 和 number
{
continue;
}
if (i != 0&&i==1)
{
canshu = canshu + arguments[i].toString();
}
if ( i > 1)
{
canshu = canshu +"|"+ arguments[i].toString();
}
}
$("#hid_fangfa").val(fangfa); //在隐藏控件中存入方法名
$("#hid_canshu").val(canshu);//在隐藏控件中存入 拼接后的参数
        $("#form1").attr("target", "_self"); //这里表示指向 的 form1 默认提交的页面 
$("#form1").submit(); //提交表单
} 

第三步: 后台通过  隐藏控件中的 方法名字不同去执行不同的方法(难道一定要循环判断隐藏控件的值才能执行不同的方法吗?难道要使用传说的反射!!!!)

亲们,你们说对了,这里唯有反射才能实现前台动态的调用后台的不同的方法。   

后台的代码需要能够通过js 动态的调用前台的方法,就必须要继承 一个类,这个类叫父类,我们这里建了一个类 叫Base,还需要继承System.Web.UI.Page,

首先我们通过Request 的方式获取 隐藏控件的值,然后通过方法名字,参数的个数 去找到该页面的对应的方法,然后执行这个方法!

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Reflection;  //需要引用反射
using System.Web;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;

public class Base:System.Web.UI.Page
{
protected override void OnInit(EventArgs e)
{
if (Page.IsPostBack)
{
string fangfa = this.Request["hid_fangfa"] == null ? "" : this.Request["hid_fangfa"].ToString(); // 获取方法名
string canshu = this.Request["hid_canshu"] == null ? "" : this.Request["hid_canshu"].ToString(); //获取参数

MethodInfo method=null;
MethodInfo[] methods=this.GetType().GetMethods(); // 获取该类中的 所有方法
for (int i = ; i < methods.Length; i++) //遍历所有方法,找到方法名字相同,并且参数个数也相同的方法
{
if (methods[i].Name == fangfa && methods[i].GetParameters().Length == canshu.Split('|').Length)
{
method = methods[i];
break;
}
}
if (method != null) //判断是否找到方法
{
string[] strs = canshu.Split('|'); //获取参数 分割后的 数组
method.Invoke(this, strs); // 执行方法
}
}
}
}

第四步:  首先要引入 我们刚才写的js,同时后台需要public partial class test1 : Base    ,继承我们写的公共类

让我们我们在前台动态的调用方法吧!!

前台  :   <input type="button" value="2个参数" onclick="gohoutai('gogo', '我是好人','222');" />

<input type="button" value="1个参数" onclick="gohoutai('gogo','222');" />

后台 :

public void gogo(string s, string dd)
{
s = "2222";
}

public void gogo(string ss) 
{
ss = "2222";
}

然后我们打入断点 , 希望能够命中 !!!!!!(成功打入断点)

至此 我们的 前台调用后台的 封装到此结束,我想你在也没有见过这么牛逼的封装了吧!!代码的世界太疯狂了!!!!!!!!!!!!!!!!!

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

看了我写的这么多,你们发现一个东西没有,好像界面还是刷新了,如果我想 不刷新提交后台怎么办?而且我还想 像 ajax 一样执行完成后能够    返回参数,能够在前台继续执行! 我想我们是在颠覆  webform的 写法吧!!!!!

打造颠覆你想象中的高性能,轻量级的webform框架---js直接调后台的封装(第三天)的更多相关文章

  1. 打造 高性能,轻量级的 webform框架---js直接调后台(第二天)

    问题2: 每次与后台打交道 都需要写一些自己都看不太懂的事件,而且传参数很麻烦,这就是.net 封装的事件,如何解决呢?        首先以为webfrom事件,都需要写 服务器控件来绑定后台的事件 ...

  2. 打造颠覆你想象中的高性能,轻量级的webform框架-----如何替换webform的垃圾控件(第一天)

    前文描述: 随着.net  推出 MVC框架以来,webform 与 mvc 的争论一直没有停止过,一直以来 mvc 的 拥护者远远高于 webform,但是webfrom的有些优势又是mvc而无法替 ...

  3. 打造颠覆你想象中的高性能,轻量级的webform框架---无刷新提交后台并返回参数(第五天)

    问题5:  使用aspx 页面执行后台方法,总是要刷新整个页面?我想提交后台不刷新页面,同时返回参数 执行前台的js 脚本,就是说类似于像 ajax 的效果一样,那我们该怎么做呢? 大家是否已经看了前 ...

  4. 又一个高性能轻量级的iOS模型框架YYModel

    前言 iOS的模型框架其实有很多了,去年研究过Mantle,也了解过JSONModel.MJExtension,最近的项目项目优化的时候,再次考虑,基于轻量级.高性能的考虑,最终选择了YYModel. ...

  5. 0930MySQL中实现高性能高并发计数器方案(例如文章点击数)

    转自http://www.jb51.net/article/56656.htm 这篇文章主要介绍了MySQL中实现高性能高并发计数器方案,本文中的计数器是指如文章的点击数.喜欢数.浏览次数等,需要的朋 ...

  6. 基于Thrift的跨语言、高可用、高性能、轻量级的RPC框架

    功能介绍 跨语言通信 方便的使Java.Python.C++三种程序可以相互通信 负载均衡和容灾处理 方便的实现任务的分布式处理 支持服务的水平扩展,自动发现新的服务节点 能够兼容各种异常情况,如节点 ...

  7. 为WPF中DropShadowBitmapEffect提供轻量级的替代品

    原文:为WPF中DropShadowBitmapEffect提供轻量级的替代品 为WPF中DropShadowBitmapEffect提供轻量级的替代品                         ...

  8. std::string的Copy-on-Write:不如想象中美好(VC不使用这种方式,而使用对小字符串更友好的SSO实现)

    Copy-on-write(以下简称COW)是一种很重要的优化手段.它的核心思想是懒惰处理多个实体的资源请求,在多个实体之间共享某些资源,直到有实体需要对资源进行修改时,才真正为该实体分配私有的资源. ...

  9. 快速电路仿真器(FastSPICE)中的高性能矩阵向量运算实现

    今年10-11月份参加了EDA2020(第二届)集成电路EDA设计精英挑战赛,通过了初赛,并参加了总决赛,最后拿了一个三等奖,虽然成绩不是很好,但是想把自己做的分享一下,我所做的题目是概伦电子出的F题 ...

随机推荐

  1. C# 字符串转JSON

    一.简单小结 C# 中 String 转 JSON var items = JsonConvert.DeserializeObject<class>(stringJSON); 这里的 cl ...

  2. (PHP)redis String(字符串)操作

    /** * * String操作 * 字符串操作 * */ //设置键值:成功返回true,否则返回false,键值不存在则新建,否则覆盖 $redis->set('string', 'hell ...

  3. KONG -- 图形化管理(Kong Dashboard)

    前面安装的 KONG 的版本是社区版的 1.0.2,官方的 KONG Manager 好像只有企业版才提供.在 github 上找了一个开源的图形化管理应用 -- Kong Dashboard (ht ...

  4. Centos下搭建nginx反向代理

    上一节已经用编译的方式搭建好了一个nginx,链接在下面 https://www.toutiao.com/i6693130510777975300/ 然后这次我们把上次搭建好的nginx作为反向代理的 ...

  5. 总结工作中用到的ES6语法,方便工作中查看,也总结一下经验

    1.模板字符串: 表现形式:${} 举例子: import axios from 'axios'; let base = 'https://www.baidu.com/home/msg/data/pe ...

  6. 与Webpack最后的战斗

    今天用自己搭的脚手架做react项目,终于还是在图片加载的地方出错了.决定好好地看一次最新的官网.顺带写个完整的教程.

  7. 7、python数据类型之集合set

    数据类型之集合setset 不允许重复的无序集合,不能通过下标取值,因为无序1.创建   创建空集合   s ={} 默认类型为字典,所以不是空集合,空集合如下   s = set()   s = { ...

  8. Excel去除空行

    本文转载至:https://baijiahao.baidu.com/s?id=1590204478648348952&wfr=spider&for=pc,需要详细信息可链接查看 方法一 ...

  9. python入门之random模块

    #!/usr/bin/env python #_*_encoding: utf-8_*_ import random print(random.random()) #生成一个在0到1之间的随机浮点数 ...

  10. Ubuntu14.04下sogou输入法的输入框只显示英文不显示中文的问题

    解决方法:首先强制更新,把依赖文件全部安装 sudo apt-get install -f 如果仍然不管用,删除sogou的配置文件,在~/.config目录下,一般情况下是SogouPY.Sogou ...