博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
魔方NewLife.Cube升级v2.0
阅读量:6290 次
发布时间:2019-06-22

本文共 1575 字,大约阅读时间需要 5 分钟。

 魔方是一套集成权限管理的MVC管理后台,最具特色功能是模版覆盖机制,是XCode实体类的最佳搭档!

v2.0.2017.1126   借助Ajax支持高级操作,如:删除选中、批量启用禁用等

用户管理增加批量启用、批量禁用,看看效果:

选中要操作的行,上方工具栏的批量操作区域按钮会从灰变亮,(取消所有选中时该区域会变灰)。点击“批量启用”,后台发起Ajax请求到EnableSelect动作,处理完成后显示提示文本,然后刷新页面。

根据魔方的模版覆盖机制,在User视图下增加名为 _List_Toolbar_Batch.cshtml 的视图

表示在显示User的列表页时,使用该视图覆盖全局默认视图,(_List_Toolbar_Batch.cshtml的全局默认视图其实为空)。

该批量操作视图位于工具栏第二位,左边是添加按钮,右边是查询条件。

视图内容如下:

@using NewLife.Common;@{    var user = ViewBag.User as IUser ?? User.Identity as IUser;    var fact = ViewBag.Factory as IEntityOperate;    var enableSelect = this.EnableSelect();}@if (enableSelect){        }

魔方会拦截所有带有data-action的按钮和超链接,改为ajax向后端发起请求。

data-fields 表示发起请求时需要携带的参数所在控件的名字,keys就是每一行开头checkbox的控件名。

服务端代码如下:

/// 批量启用/// /// 
[EntityAuthorize(PermissionFlags.Update)]public ActionResult EnableSelect(String keys){ var count = 0; var ids = Request["keys"].SplitAsInt(); if (ids.Length > 0) { //var list = UserX.FindAll(UserX._.ID.In(ids)); Parallel.ForEach(ids, id => { var user = UserX.FindByID(id); if (user != null && !user.Enable) { user.Enable = true; user.Save(); Interlocked.Increment(ref count); } }); } return JsonRefresh("共启用[{0}]个用户".F(count));}

MVC处理keys时只取第一个,不得不改用Request["keys"]。

keys里面就是选中项的主键,这里用Parallel并行计算来进行批量更新。

来看看后端响应:

魔方统一了Ajax响应格式,result表示成功失败,data是提示文本,特殊场合还可以响应结构化数据,url表示显示文本后要跳转的url,[refresh]特指刷新当前页。

 

借助魔方v2.0的Ajax机制,普通C#工程师可以无需编写js脚本即可完成各种高级操作!

 

源码地址:

海外地址:

 

我的博客即将同步至腾讯云+社区,邀请大家一同入驻。

转载地址:http://zfkta.baihongyu.com/

你可能感兴趣的文章