Devexpress 使用经验 —— ASPxGridView前后台交互写法推荐
这里的格式是仁者见仁智者见智,这篇随笔只是我在工作过程中总结出的阅读性高,对我来说效率较高的写法。 ASPX:
<dx:ASPxGridView ID="ASPxGridViewLink" runat="server" AutoGenerateColumns="False" Width="100%" DataSourceID="ObjectDataSourceLink" KeyFieldName="LinkID"
ClientInstanceName="gridLink" OnCustomCallback="ASPxGridViewLink_CustomCallback">
<ClientSideEvents EndCallback="onASPxEndCallback" />
</dx:ASPxGridView>
关键之处:
1. 给GridView控件一个前端ID ClientInstanceName,
2. 给GridView控件一个响应"前端回调"的方法 OnCustomCallback
C#
protected void ASPxGridViewLink_CustomCallback(object sender, DevExpress.Web.ASPxGridView.ASPxGridViewCustomCallbackEventArgs e)
{
JSONObject jsonToken = JSONConvert.DeserializeObject(e.Parameters);
JSONObject jsonParams = (JSONObject)jsonToken["params"];
string command = jsonToken["action"].ToString();
if (command == "AddLink")
addLink(sender as DevExpress.Web.ASPxGridView.ASPxGridView, jsonParams);
} void addLink(DevExpress.Web.ASPxGridView.ASPxGridView s, JSONObject e)
{
string linkName = e["linkName"].ToString(),
linkUrl = e["linkUrl"].ToString(),
provinceId = null,
provinceName = null,
cityId = null,
cityName = null; bool isDistrict = e["isDistrict"].ToString() == "true"; int orderNum = Convert.ToInt32(e["sortNum"]); ... ... }
关键之处:
1. 响应"前段回调"的方法中的e.Parameters就是前端传回来的参数,一般来说它的类型为String, 如果有多个参数传回,最好封装为JSON格式,然后在后台解析
2. 将JSON的操作和参数解析,针对不同的操作写对应的方法,并传入参数
JS
function doAddLink() {
var token = JSON.stringify({
action: "AddLink",
params: {
linkName: tbName.GetValue(),
linkUrl: tbLink.GetValue(),
sortNum: tbSort.GetValue(),
isDistrict: chIsDistrict.GetValue(),
provinceId: comboProvicne.GetValue(),
provinceName: comboProvicne.GetText(),
cityId: comboCity.GetValue(),
cityName: comboCity.GetText()
}
});
gridLink.PerformCallback(token);
}
关键之处: 封装包含 action(执行的操作) 和 params(操作的参数) 的 JSON, 通过 GridView的前端ID 调用PerformCallback方法,并且传入JSON
其他ASPx控件Callback操作也同样适用。
其实只需一个ASPxCallback控件就可以实现复杂的Ajax交互效果。我们知道ASPxCallback是Devexpress里面一个很纯净的专门处理异步操作的控件,像很多自带Callback的控件比如ASPxGridView, ASPxComboBox, ASPxCallbackPanel等等或多或少的附带了ASPxCallback控件的功能。
下面这个示例来简单介绍ASPxCallback如何前后台交互,如何相互调用方法
首先需要给全局JS添加一个方法:
window.onASPxEndCallback = function (s, e) {
var script = s.cpScript;
if (!(script === 'undefined')) {
var func = new Function(script);
func.call();
delete s.cpScript;
}
}
这段JS是获取callback控件的cpScript属性,这个属性在后台会相应的赋值,这个值是一段可执行的js方法,如果存在该值,那么转换为Function,并且执行,执行完之后立即删除。
ASPX
<dx:ASPxCallback ID="ASPxCallback1" runat="server" OnCallback="ASPxCallback1_Callback" ClientInstanceName="callback">
<ClientSideEvents EndCallback="onASPxEndCallback" />
</dx:ASPxCallback>
同样给ClientInstanceName 赋值, 添加响应前段回调的方法 OnCallback, 关键添加 ”<ClientSideEvents EndCallback="onASPxEndCallback" />“回调方法执行完之后要调用onASPxEndCallback
C#
protected void ASPxCallback1_Callback(object source, DevExpress.Web.ASPxCallback.CallbackEventArgs e)
{ DevExpress.Web.ASPxCallback.ASPxCallback callback = source as DevExpress.Web.ASPxCallback.ASPxCallback; // 获取这个callback // 具体方法执行的内容 // 以下是后台调用前台的三种方法 callback.JSProperty["cpScript"] = string.format("alert('{0} 执行成功。'); location.href='{1}'", xxxx, yyyy); callback.JSProperty["cpScript"] = string.format(@" var name = '{0}'; function love(n){{ alert('I love you ' + n); }} // 在string.format中,'{' 需要用'{{'来转义,同样 '}'需要用'}}'来转义 love(name); ", xxxx); callback.JSProperty["cpScript"] = string.format("someFunction({0})", xxxx); // 这里的 someFunction 是在前段js里写的方法 }
JS
这里是前台调用后台的方法
fucntion onButtonClicked(){
var param = JSON.stringify{
a: '1',
b: '2'
}
callback.PerformCallback(param); // PerformCallback执行之后会调用后台的 void ASPxCallback1_Callback 事件,后台的操作在这里处理。
}
总而言之,Devexpress实在是非常强大控件,仅仅一个简单的ASPxCallback 就可以省略.NET中用各种ashx来处理ajax请求, 大大提高了编码的阅读性。
下一篇将展示一个简单地区级联操作。
Devexpress 使用经验 —— ASPxGridView前后台交互写法推荐的更多相关文章
- Devexpress 使用经验 —— ASPxGridView命令行自定义按钮灵活使用
ASPX <dx:ASPxGridView ID="ASPxGridView1" runat="server" DataSourceID="Ob ...
- DevExpress之ASPxGridView笔记(1)
1.设置Row(某列)输出格式,例如,在数字前加美元符.每3位以逗号隔开及设置小数点后两位: <dx:GridViewDataTextColumn FieldName="SHOUHUI ...
- ajax的底层前后台交互
为什么用ajax或者它的优点: 异步加载数据,无需切换页面 更加的用户体验,局部刷新,及时验证,操作步骤简化: 节省流量 js控制数据的加载,更加灵活多用. 底层就是XMLHttpRequest对象: ...
- devexpress中ASPxGridView控件初始化赋值
写在ASPxGridView中OnCellEditorInitialize="ASPxGridView_progoods_CellEditorInitialize" 事件中: / ...
- jquery ajax返回json数据进行前后台交互实例
jquery ajax返回json数据进行前后台交互实例 利用jquery中的ajax提交数据然后由网站后台来根据我们提交的数据返回json格式的数据,下面我来演示一个实例. 先我们看演示代码 代码如 ...
- JAVA配置&注解方式搭建简单的SpringMVC前后台交互系统
前面两篇文章介绍了 基于XML方式搭建SpringMVC前后台交互系统的方法,博文链接如下: http://www.cnblogs.com/hunterCecil/p/8252060.html htt ...
- ajax实现异步前后台交互,模拟百度搜索框智能提示
1.什么是异步?在传统的网站项目中,填写一堆数据,最后点击提交,在点击提交的这一刻才实现数据提交,前后台交互.在你点击提交之前数据是没有提交到后台的.这样就会造成很大的不便.比如,我填了一大堆数据,结 ...
- 前后台交互经常使用的技术汇总(后台:Java技术,前台:Js或者Jquery)
1:由于针对特定的前后台交互用到的知识总结,所以不大量贴代码,主要给出思路,方便自己以后脑补和技术总结,当然也希望可以帮助到别人. 后台Json和其他格式转化,之前总结过Json和对象,集合,字符串的 ...
- WebSocket前后台交互
其实对于前后台交互有很多种方法(只列举我知道的,嘻嘻): 1:from 表单: 使用场景——小信息量提交给后台 2:ajax(跨域的话用jsonp): 可以进行多量的前后台信心传递: 但实时性不高,不 ...
随机推荐
- 嵌套滚动demo
https://github.com/luv135/NestedScrollingDemo https://github.com/ggajews/nestedscrollingchildviewdem ...
- 【2015年最新App Store退款流程详解】最详细AppStore退款流程图文教程
本帖最后由 想吐就吐出来 于 2015-7-1 14:25 编辑 如果你一不小心买错了iOS软件,从App Store上下载了游戏或软件后悔了,那怎么办?可以退款吗?答案是可以的!苹果这点还是很人性化 ...
- C++ Prime:函数
局部静态对象: 某些时候,有必要令局部变量的生命周期贯穿函数调用及之后的时间.可以将局部变量定义成static类型从而获得这样的对象.局部静态对象在程序执行路径第一次经过对象定义语句时初始化,并且直到 ...
- bzoj1233
首先这道题有一个很重要的贪心就是 在保证所有干草堆都能参与搭建的前提下,我们尽量使最底层的宽度小,这样搭起来的的干草堆高度一定是最高的 当我们以第i个干草堆为一层,显然最优的情况是找到一个尽可能小的j ...
- C#利用NPOI生成具有精确列宽行高的Excel文件
前言 NPOI是操作Excel的神器,导出导入快如闪电, 但是SetColumnWidth函数个人感觉不会用,怎么弄都无法控制好,因为他是以字符数量去设置宽度,实际上Excel列宽还有个像素的概念,更 ...
- C# Web版报表
1.添加ReportViewer 2.添加ObjectDataSource 3.须添加一个ScriptManager 4.添加并设计一个报表用数据集 5.设计rdlc报表,数据源选择第4步的数据集 6 ...
- 避免由于Windows Update自动安装安全补丁导致VM意外重启
最近我们遇到一些客户报告他们的Windows VM被意外重启导致了其服务中断,我们查看了Event Log发现这个重启的操作时由于Windows update自动安装了安全补丁导致的重启操作.默 ...
- Docker在云环境中的应用实践初探:优势、局限性与效能评测
作者 商之狄 发布于 2014年11月10日 本文依据笔者所在团队的一些近期开发和应用的实践,整理出一些有意义的信息,拿出来和社区分享.其中既包括在云端应用Docker与相关技术的讨论,同时也有实施过 ...
- HDU-2952 Counting Sheep (DFS)
Counting Sheep Time Limit : 2000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) Tota ...
- android开发环境与工具使用相关备忘录
一.名称简介 1.ADT(Android Development Tools) 可以简单理解为在eclipse下开发安卓的插件或工具包. 查看当前ADT版本方法:help-> about ecl ...