ASP.NET中一种超简单的Ajax解决方案

时间:2021-08-29 12:59:40

为什么是Ajax2?

因为之前有一个blqw.Ajax,并且已经在项目中投入使用了,但是没有这个方便,这个是后来才弄的,为了纪念第一版的blqw.Ajax,所以这个就2了...

话说看了评论才发现,原来之前有组件已经实现类似的功能了

不过我不是很理解的是AjaxPro为什么一定要配置Handler,直接在后端文件中完成不好吗?这样看,似乎我这个也还是有点自己的特色的...

  调用方式

blqw.Ajax2调用方式

都说了是超简单的,所以调用起来就一定是超简单的了.....

建立一个web项目

引用blqw.Ajax2

ASP.NET中一种超简单的Ajax解决方案

ASP.NET中一种超简单的Ajax解决方案

对了,聪明你的一定已经知道了,我只是向页面中注入了一段js,利用了一个同步ajax请求模拟出的这样一个效果而已

技术上实现并不难

    window.blqw = window.blqw || {};

    blqw.Ajax = blqw.Ajax || {};

    blqw.Ajax.GetRequest = function () {

        if (window.ActiveXObject) {

            try {

                return new ActiveXObject('Msxml2.XMLHTTP');

            } catch (e) {

                return new ActiveXObject('Microsoft.XMLHTTP');

            }

        }

        else if (window.XMLHttpRequest) {

            return new XMLHttpRequest();

        }

    }

    blqw.Ajax.Throw = function(e){{

            function AjaxError(message,stack,type){{

                this.name = 'AjaxError';

                this.type = type;

                this.message = message;

                this.stack = stack;

                this.innerError = null;

                this.toString = function () {{

                                    return 'ajaxerr:' + this.message;

                                }};

            }};

            var err = new AjaxError(e.message,e.stack,e.type);

            var e1 = err;

            while(e.innerError){{

                e = e.innerError;

                e1.innerError = new AjaxError(e.message,e.stack,e.type);

                e1 = e1.innerError;

            }}

            return err;

        }}

    blqw.Ajax.Exec = function (method, args) {

            var getStr = function (obj) {

                if (obj == null) return '';

                var type = typeof (obj);

                switch (type) {

                    case 'number':

                    case 'boolean':

                        return obj.toString();

                    case 'string':

                        return encodeURIComponent(obj.replace('\0', '\0\0'));

                    case 'undefined':

                        return 'undefined';

                    case 'function':

                        try {

                            return arguments.callee(obj());

                        } catch (e) {

                            return 'null';

                        }

                    case 'object':

                        type = Object.prototype.toString.apply(obj);

                        switch (type) {

                            case '[object Date]':

                                return encodeURIComponent(obj.getFullYear() + '-' +

                            (obj.getMonth() + 1) + '-' +

                            obj.getDate() + ' ' +

                            obj.getHours() + ':' +

                            obj.getMinutes() + ':' +

                            obj.getSeconds() + '.' +

                            obj.getMilliseconds());

                            case '[object RegExp]':

                                return encodeURIComponent(obj.toString().replace('\0', '\0\0'));

                            case '[object Array]':

                                var arr = [];

                                for (var i in obj)

                                    arr.push(arguments.callee(obj[i]));

                                return arr.join(',');

                            case '[object Object]':

                                return '[object Object]';

                        }

                        break;

                }

            }

            var arr = [];

            for (var i = 0; i < args.length; i++) {

                arr.push(getStr(args[i]));

            }

            url = window.location.href;

            var req = blqw.Ajax.GetRequest();

            req.open('POST', url, false);

            req.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=utf-8');

            var ret = req.send('blqw.ajaxdata=' + arr.join('\0') + '&blqw.ajaxmethod=' + method);

            if (req.status == 200) {

                var html = req.responseText;

                var data = eval('(' + html+ ')');

                if ('v' in data) {

                    eval(data.v);

                } 

                if ('e' in data) {

                    throw blqw.Ajax.Throw(data.e);

                } else {

                    return data.d;

                }

            } else {

                alert('出现错误');

            }

        } 

window.GetString=function(){return blqw.Ajax.Exec('GetString',arguments);}

向页面中添加的js

事实上正式使用的js是压缩了的

ASP.NET中一种超简单的Ajax解决方案

  特点

当然,如果只有这样,你们一定就骂我的......

我为他增加了一些实用的方法

1.没有form也可以

  如果页面中没有form,只要把<% blqw.Ajax2.Register(this); %>写在aspx页面中就可以了

2.返回类型object

ASP.NET中一种超简单的Ajax解决方案

3.异常处理

ASP.NET中一种超简单的Ajax解决方案

4.方便的js写入

  写入alert

ASP.NET中一种超简单的Ajax解决方案

  写入变量 或 修改变量

ASP.NET中一种超简单的Ajax解决方案

  写入js

ASP.NET中一种超简单的Ajax解决方案

  缺陷

  1. 参数仅支持System下的基础类型
  2. Ajax请求中无法取消
  3. 不支持ref out params 这些东西....
  4. 安全性不够,需要自己在代码中实现(关于这点我自己也一直在纠结,如果园友们有好的方案可以提点一下我啊)

  Demo下载

blqw.Ajax2Demo.rar

  源码下载

https://code.csdn.net/jy02305022/blqw-ajax2

事实上他只有2个文件

Ajax2.cs

AjaxMethod.cs

ASP.NET中一种超简单的Ajax解决方案的更多相关文章

  1. ASP&period;net中导出Excel的简单方法介绍

    下面介绍一种ASP.net中导出Excel的简单方法 先上代码:前台代码如下(这是自己项目里面写的一点代码先贴出来吧) <div id="export" runat=&quo ...

  2. ASP&period;NET中登录功能的简单逻辑设计

     ASP.NET中登录功能的简单逻辑设计                               概述                               逻辑设计             ...

  3. ASP&period;NET中几种加密方法

    下面就是ASP.NET中几种加密方法.加密算法有两种,也就是上面提到的MD5和SHA1,这里我举的例子是以MD5为例,SHA1大致相同,只是使用的类不一样. MD5的全称是Message-Digest ...

  4. HTML页面中5种超酷的伪类选择器&colon;hover效果

    想在自己的网站中应用超酷的hover效果吗?也许你可以从如下的这些实例中获得一些灵感,如果你喜欢这些效果,也可以直接拷贝代码并应用到你的站点. 给平淡的站点带来活力 hover效果能给网页增加一些动态 ...

  5. &lt&semi;经验杂谈&gt&semi;C&num;中一种最简单、最基本的反射(Reflection):通过反射获取方法函数

    说起反射之前和很多用C#/.net的同仁们一样,相比于一般应用层对数据的增删改查总有点觉得深奥到难以理解.其实程序这东西,用过.实践过就很简单,我一直这么认为. 先说下概念:反射 Reflection ...

  6. 在ASP&period;Net中两种利用CSS实现多界面的方法

    通过使页面动态加载不同CSS实现多界面(类型于csdn的blog): 方法一: <%@page language="C#"%><%@import namespac ...

  7. ASP&period;NET中26种性能优化方法

    系统类  Type类,Object类,String类, Arrary类,Console类, Exception类,GC类, MarshalByRefObject类, Math类. DateTime结构 ...

  8. Web页面中5种超酷的Hover效果

    hover 效果能给网页增加一些动态效果,并且使得站点更具有活力.原来的做法是使用javascript来实现这些动态效果,但是随着CSS3的引入和现代浏览器 的支持,我们可以用纯粹的CSS代码来实现这 ...

  9. JQuery在asp&period;net中三种ajax传值

    1)通过webservice,注意去掉注释[System.Web.Script.Services.ScriptService]这行前的注释 2)通过aspx.cs文件中的静态方法 3)通过aspx文件 ...

随机推荐

  1. 当云遇见APP性能测试会怎样?

    一个测试人员应该明白,无论是在云内部或是外部,对一个应用程序而言,需要进行测试的地方都是一样的.最终用户只关注的是一个无缺陷的高性能的应用程序,而不关心应用程序位于哪里.在大多数的云服务协议里,都会提 ...

  2. Awesomplete - 零依赖的简单自动完成插件

    Awesomplete 是一款超轻量级的,可定制的,简单的自动完成插件,零依赖,使用现代化标准构建.你可以简单地添加 awesomplete 样式,让它自动处理(你仍然可以通过指定 HTML 属性配置 ...

  3. 《深入Java虚拟机学习笔记》- 第15章 对象和数组

    1.针对对象的操作码 实例化一个新对象需要通过new操作码来实现. 对象的创建 操作码 操作数 说明 new index 在堆中创建一个新的对象,将其引用压入栈 new操作码后面紧跟一个无符号16位数 ...

  4. linux系统文件属性-硬连接、软连接

    1 硬链接概念 硬链接是指通过索引节点(Inode)来进行链接,在Linux(ext2,ext3)文件系统中,保存在磁盘分区中的文件不管是什么类型都会给它分配一个编号,这个编号被称为索引节点编号(In ...

  5. 清除和新建WordPress数据库

    由于在本地已经安装过一次wordpress.所以假设第二次安装的时候 localhost/wp-admin/install.php 会显示你已经安装过了.所以须要把MySQL的数据库信息清除掉,或者另 ...

  6. gridview列超链接的几种设置方法

    <asp:GridView ID="GridView1" runat="server" Width="100%" AutoGenera ...

  7. mysql数据库的维护,备份和复制

    在数据库运行时维护数据库 执行mysql数据库维护的方法之一就是连接mysql服务器,并告诉它做什么事, 如对myisam数据表进行检查或者修复, 可以使用check table tbname或rep ...

  8. hdu 4549 矩阵快速幂

    题意: M斐波那契数列F[n]是一种整数数列,它的定义如下: F[0] = aF[1] = bF[n] = F[n-1] * F[n-2] ( n > 1 ) 现在给出a, b, n,你能求出F ...

  9. 在T-SQL语句中访问远程数据库

    1.启用Ad Hoc Distributed Queries 在使用openrowset/opendatasource前搜先要启用Ad Hoc Distributed Queries服务,因为这个服务 ...

  10. linux和windows动态库加载路径区别

    # linux和windows动态库加载路径区别 ### 简介------------------------------ linux加载动态库的路径是系统目录/lib和/usr/lib.- wind ...