ASP.NET中一种超简单的Ajax解决方案
为什么是Ajax2?
因为之前有一个blqw.Ajax,并且已经在项目中投入使用了,但是没有这个方便,这个是后来才弄的,为了纪念第一版的blqw.Ajax,所以这个就2了...
话说看了评论才发现,原来之前有组件已经实现类似的功能了
不过我不是很理解的是AjaxPro为什么一定要配置Handler,直接在后端文件中完成不好吗?这样看,似乎我这个也还是有点自己的特色的...
调用方式
blqw.Ajax2调用方式
都说了是超简单的,所以调用起来就一定是超简单的了.....
建立一个web项目
引用blqw.Ajax2
对了,聪明你的一定已经知道了,我只是向页面中注入了一段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是压缩了的
特点
当然,如果只有这样,你们一定就骂我的......
我为他增加了一些实用的方法
1.没有form也可以
如果页面中没有form,只要把<% blqw.Ajax2.Register(this); %>写在aspx页面中就可以了
2.返回类型object
3.异常处理
4.方便的js写入
写入alert
写入变量 或 修改变量
写入js
缺陷
- 参数仅支持System下的基础类型
- Ajax请求中无法取消
- 不支持ref out params 这些东西....
- 安全性不够,需要自己在代码中实现(关于这点我自己也一直在纠结,如果园友们有好的方案可以提点一下我啊)
Demo下载
源码下载
https://code.csdn.net/jy02305022/blqw-ajax2
事实上他只有2个文件
ASP.NET中一种超简单的Ajax解决方案的更多相关文章
- ASP.net中导出Excel的简单方法介绍
下面介绍一种ASP.net中导出Excel的简单方法 先上代码:前台代码如下(这是自己项目里面写的一点代码先贴出来吧) <div id="export" runat=&quo ...
- ASP.NET中登录功能的简单逻辑设计
ASP.NET中登录功能的简单逻辑设计 概述 逻辑设计 ...
- ASP.NET中几种加密方法
下面就是ASP.NET中几种加密方法.加密算法有两种,也就是上面提到的MD5和SHA1,这里我举的例子是以MD5为例,SHA1大致相同,只是使用的类不一样. MD5的全称是Message-Digest ...
- HTML页面中5种超酷的伪类选择器:hover效果
想在自己的网站中应用超酷的hover效果吗?也许你可以从如下的这些实例中获得一些灵感,如果你喜欢这些效果,也可以直接拷贝代码并应用到你的站点. 给平淡的站点带来活力 hover效果能给网页增加一些动态 ...
- <经验杂谈>C#中一种最简单、最基本的反射(Reflection):通过反射获取方法函数
说起反射之前和很多用C#/.net的同仁们一样,相比于一般应用层对数据的增删改查总有点觉得深奥到难以理解.其实程序这东西,用过.实践过就很简单,我一直这么认为. 先说下概念:反射 Reflection ...
- 在ASP.Net中两种利用CSS实现多界面的方法
通过使页面动态加载不同CSS实现多界面(类型于csdn的blog): 方法一: <%@page language="C#"%><%@import namespac ...
- ASP.NET中26种性能优化方法
系统类 Type类,Object类,String类, Arrary类,Console类, Exception类,GC类, MarshalByRefObject类, Math类. DateTime结构 ...
- Web页面中5种超酷的Hover效果
hover 效果能给网页增加一些动态效果,并且使得站点更具有活力.原来的做法是使用javascript来实现这些动态效果,但是随着CSS3的引入和现代浏览器 的支持,我们可以用纯粹的CSS代码来实现这 ...
- JQuery在asp.net中三种ajax传值
1)通过webservice,注意去掉注释[System.Web.Script.Services.ScriptService]这行前的注释 2)通过aspx.cs文件中的静态方法 3)通过aspx文件 ...
随机推荐
- js(ext)中,设置[!!异步!!]上传的简单进度条
代码在updateHmis的历史记录中,此处存档 handler : function() { //显示进度条 Ext.MessageBox.wait('数据上传中...','提示'); //上传数据 ...
- MySQL数据库安装与配置详解
转载提示:在原文http://www.cnblogs.com/sshoub/p/4321640.html基础上修改. 目录 一.概述 二.MySQL安装 三.安装成功验证 四.NavicatforMy ...
- css3选择器总结
1.p[class^/$/*=td]所有p标签的前面带有td/后面带有td/所有带有td的类的三种样式. 2.div:first-child/last-child/nth-child()在父元素下的第 ...
- PHP 实现单一入口 apache配置
在apache的httpd.conf加入,需要把LoadModule rewrite_module modules/mod_rewrite.so前面的“#”去掉 DocumentRoot / < ...
- luogu p2330[SCOI05] 繁忙的都市——瓶颈生成树
P2330 05四川 繁忙的都市 题目描述 城市C是一个非常繁忙的大都市,城市中的道路十分的拥挤,于是市长决定对其中的道路进行改造.城市C的道路是这样分布的:城市中有n个交叉路口,有些交叉路口之间有道 ...
- 手拼SQL小技巧,WHERE 1=1
由于项目要求,要手动拼接SQL,(不知道领导们怎么想的--),然后就再次回到原始时代,append(SQL). 但后面查询牵扯到动态多条件,如果是mybatis的话就直接 可以用<if>标 ...
- nginx简易安装
yum -y install perl-ExtUtils-Embed ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx ...
- Android应用:StatusBar状态栏、NavigationBar虚拟按键栏、ActionBar标题栏、Window屏幕内容区域等的宽高
一.屏幕中各种栏目以及屏幕的尺寸 当我们需要计算屏幕中一些元素的高度时,或许需要先获取到屏幕或者各种栏目的高度,下面这个类包含了Status bar状态栏,Navigation bar虚拟按键栏,Ac ...
- android 中View的优化
在android开发中Listview是一个很重要的组件,它以列表的形式根据数据的长自适应展示具体内容,用户可以自由的定义listview每一列的布局,但当listview有大量的数据需要加载的时候, ...
- android ontouch事件分发机制
最近开发一个项目中,banner图左右切换和下拉刷新手势有冲突,为此去研究了事件分发,网上资料一大抄,有些讲的不对有些讲的不全,结合了网上一些博文以及源码总结如下 一个完整的触摸事件包含down,m ...