easyui datagrid 单元格编辑 即见即所得,MVC菜单维护,扫描增加
效果如图:

参见 EasyUI 官方 Demo 及文档
@{
ViewBag.Title = "Index";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<script src="~/jquery-easyui-1.4.2/locale/easyui-lang-zh_CN.js"></script>
<table id="datagrid" class="easyui-datagrid" title="" style="width: 100%;"
data-options="rownumbers:true,autoRowHeight:false,pagination:true,toolbar:'#tb',footer:'#ft',fit:true,
pageSize:,singleSelect:true,collapsible:true,url:'@Url.Action("GetGridJSON")',method:'post',fixed:true,
remoteSort:false,onClickCell: onClickCell,onAfterEdit:onAfterEdit,
multiSort:true">
<thead>
<tr>
<th data-options="field:'Id',checkbox:true"></th>
<th data-options="field:'Url',editor:'text'">Url</th>
<th data-options="field:'MenuNo',editor:'text'">MenuNo</th>
<th data-options="field:'MenuLevel',editor:'text'">MenuLevel</th>
<th data-options="field:'MenuName',editor:'text'">MenuName</th>
</tr>
</thead>
</table>
<div id="tb" style="padding: 2px 5px;">
<a href="#" class="easyui-linkbutton" iconcls="icon-add" plain="true">增加</a>
@*<a href="#" class="easyui-linkbutton" iconcls="icon-edit" plain="true">修改</a>*@
<a href="#" class="easyui-linkbutton" iconcls="icon-cancel" plain="true">删除</a>
<a href="#" class="easyui-linkbutton" iconcls="icon-xls" plain="true">导出Excel</a>
<a href="#" class="easyui-linkbutton" iconcls="icon-scan" plain="true">扫描添加</a>
<select onchange="$('#datagrid').datagrid({singleSelect:(this.value==0)})">
<option value="">选中单行</option>
<option value="">选中多行</option>
</select>
<input class="easyui-textbox" id="MenuNo" value="" name="MenuNo" data-options="prompt:'MenuNo:'" style="height: 22px; width: 120px">
<input class="easyui-textbox" id="url" value="" name="url" data-options="prompt:'url:'" style="height: 22px; width: 120px">
<input class="easyui-textbox" id="MenuName" value="" name="MenuName" data-options="prompt:'MenuName:'" style="height: 22px; width: 120px">
<a href="#" class="easyui-linkbutton" onclick="doSearch()" iconcls="icon-search">查询</a>
<div id="w" class="easyui-window" title="Modal Window" data-options="modal:true,closed:true" style="padding: 10px;">
</div>
</div>
<script>
var UrlActionToExcel = "@Url.Action("ToExcel")";
$(document).ready(function () {
$("[iconcls='icon-scan']").click(function () {
$.ajax({
type: "GET",
url: "scan",
async: false, success: function (data) {
doSearch();
parent.showMsgTopCenter("提示", "已经生成" + data + "行记录");
}
});
});
});
</script>
<script type="text/javascript">
$.extend($.fn.datagrid.methods, {
editCell: function (jq, param) {
return jq.each(function () {
var opts = $(this).datagrid('options');
var fields = $(this).datagrid('getColumnFields', true).concat($(this).datagrid('getColumnFields'));
for (var i = ; i < fields.length; i++) {
var col = $(this).datagrid('getColumnOption', fields[i]);
col.editor1 = col.editor;
if (fields[i] != param.field) {
col.editor = null;
}
}
$(this).datagrid('beginEdit', param.index);
for (var i = ; i < fields.length; i++) {
var col = $(this).datagrid('getColumnOption', fields[i]);
col.editor = col.editor1;
}
});
}
});
var editIndex = undefined;
function endEditing() {
if (editIndex == undefined) { return true }
if ($('#datagrid').datagrid('validateRow', editIndex)) {// 检测 数据是否发生 改变
$('#datagrid').datagrid('endEdit', editIndex);// 触发 onAfterEdit 方法
editIndex = undefined;
return true;
} else {
return false;
}
}
function onClickCell(index, field, data) {
if (endEditing()) {
$('#datagrid').datagrid('selectRow', index)
.datagrid('editCell', { index: index, field: field, data: data });
editIndex = index;
}
}
function onAfterEdit(rowIndex, rowData, changes) {// onAfterEdit 在 rowData 本行数据 ,changes 发生改变的数据
for (change in changes) {
var temp = {};
temp[change] = changes[change];
temp["Id"] = rowData.Id;
temp["MenuLevel"] = rowData.MenuLevel; // 这是 int 类型 ,后台 只排除 string == null,所有要加上
$.ajax({
type: "POST", url: "updateCell", traditional: true, data: temp,//每次 只修改 一行数据中的 某一个字段
async: false, dataType: "json", sunccess: function (data) {//dataType 没有限制
parent.showMsgTopCenter("提示", "已修改" + data + "行数据");
}
})
}
}
</script>
public void UpdateCell(Sys_Menu model)
{
ef_Help.ModifyWithOutproNames<Sys_Menu>(model);
Response.Write(db.SaveChanges());
Response.End();
}
public int Scan()
{
var My_Assembly = Assembly.GetExecutingAssembly();// 获得 当前 正在 运行 的程序集
My_Assembly.GetType().GetMethods();
string[] ReturnTyoes = { "ActionResult", "Int32", "String" };//只接收 返回值类型 为 这3中的方法。
var Models = db.Sys_Menu.ToList();// 菜单集合
List<string> UrlArr = new List<string>();// 扫描 Url 集合
foreach (Type type in My_Assembly.GetTypes())//遍历所有 类
{
if (type.Name.Contains("Controller") && type.FullName.Contains("Areas"))// 只扫描 Areas 下的 Controller 类
{
var FullName = type.FullName.Split('.');
var AreaName = FullName[];//获得区域名称
var ControllerName = FullName[].Substring(, FullName[].Length - "Controller".Length);//获得 Control 名称
foreach (var Method in type.GetMethods())//遍历 所有 方法
{
if (ReturnTyoes.Contains(Method.ReturnType.Name) && Method.DeclaringType.Name != "Object")// 排除 基类 Object ,及它的方法
{
var ActionNameAttribute = Method.GetCustomAttributes(typeof(ActionNameAttribute), false);
var MethodName = ActionNameAttribute.Length > ? ((ActionNameAttribute)Method.GetCustomAttributes(typeof(ActionNameAttribute), false)[]).Name : Method.Name;
var Url = string.Format("/{0}/{1}/{2}", AreaName, ControllerName, MethodName);//获得 真实 action (有ActionNameAttribute标记的 ) if (Models.Where(X => X.Url == Url).FirstOrDefault() == null && !UrlArr.Contains(Url))// 排除 已有的Url
{
UrlArr.Add(Url);
}
}
}
}
}
foreach (var url in UrlArr)
{
db.Sys_Menu.Add(new Sys_Menu()
{
MenuLevel = ,
MenuName = "未知",
MenuNo = "未知",
Url = url
});
} return db.SaveChanges();
}
easyui datagrid 单元格编辑 即见即所得,MVC菜单维护,扫描增加的更多相关文章
- EasyUI Datagrid 单元格编辑
3:对于单元格的编辑 $('#Units').datagrid({ pageNumber: 1, //url: "@ViewBag.Domain/Paper/GetQuestionUnit& ...
- easyui datagrid 单元格编辑(cell editing)
demo中有row editing 项目中发现个cell editing,但是有bug,修改好了 主要实现功能:单击数据表格单元格,编辑单元格数据 js代码如下: $.extend($.fn.data ...
- easyui datagrid 单元格 编辑时 事件 修改另一单元格
//datagrid 列数据 $('#acc').datagrid({ columns : [ [ { field : 'fee_lend', title : '收费A', width : 100, ...
- easyui datagrid 单元格编辑 自动聚焦 、全选
$.extend($.fn.datagrid.methods, { editCell: function (jq, param) { return jq.each(function () { var ...
- EasyUI datagrid单元格文本超出显示省略号,鼠标移动到单元格显示文本
nowrap : true; 是前提 $('#×××').datagrid({ nowrap : true,//设置为true,当数据长度超出列宽时将会自动截取 }); 省略号样式: <sty ...
- easyui datagrid单元格实现溢出文本显示省略号的效果。
Css .datagrid-btable .datagrid-cell{padding:6px 4px;overflow: hidden;text-overflow:ellipsis;white-sp ...
- easyui datagrid 单元格加进度条(亲测可用)
{field: 'DataItemNum', title: '数据完整度', width: 100, formatter: function (v, r, i) { var p = (v / 27) ...
- Datagrid扩展方法InitEditGrid{支持单元格编辑}
//-----------------------------------------------------------------/******************************** ...
- Datagrid扩展方法onClickCell{easyui-datagrid-扩充-支持单元格编辑}
//-----------------------------------------------------------------/******************************** ...
随机推荐
- Java爬虫,信息抓取的实现(转)
转载请注明出处:http://blog.csdn.net/lmj623565791/article/details/23272657 今天公司有个需求,需要做一些指定网站查询后的数据的抓取,于是花了点 ...
- POJ 2112 Optimal Milking (二分 + floyd + 网络流)
POJ 2112 Optimal Milking 链接:http://poj.org/problem?id=2112 题意:农场主John 将他的K(1≤K≤30)个挤奶器运到牧场,在那里有C(1≤C ...
- 数据结构(C达到)------- 双链表
双链表中的每个节点包含两个指针域,指针域包含其后继节点的内存地址,还有一个指针所存储的存储器地址其领域前驱节点. 双向链表结点的类型描写叙述: //双向链表的类型描写叙述 typedef int El ...
- SpringMVC源代码深度分析DispatcherServlet核心的控制器(初始化)
SpringMVC是非常优秀的MVC框架,每一个框架都是为了我们提高开发效率,我们试图通过对SpringMVC的源码去了解这个框架,了解整个设计思想,框架要有扩展性,这里用的比較多是接口和抽象,是框架 ...
- 使用Inno Setup 打包jdk、mysql、tomcat、webapp等为一个exe安装包(转)
之前一直都没涉及到打包安装方面的东西,都是另一个同事负责的,使用的工具(installshield)也比较高大上一点,可是后来他离职以后接受的同事也只能是在这个基础上做个简单的配置,然后打包,可是现在 ...
- MVC中的Views下面的视图放到Views文件夹外
实战:把ASP.NET MVC中的Views下面的视图放到Views文件夹外 园子里写的文章的都是把控制器从传统的项目中的Controllers拿出来单独放,但很少几乎没有把视图从Views拿出去 ...
- NSIS:使用nsWindows.nsh头文件调整窗体大小
原文 NSIS:使用nsWindows.nsh头文件调整窗体大小 此方法只能简单实现调整窗体大小,但不完美,调整后窗体上其他的控件都需要调整大小或位置,比较麻烦,轻狂不建议使用呵! ;加头文件!inc ...
- wikioi 1034 家 实时动态的网络流量(费用流)
因为随着时间的推移.网络侧变得,因此,常见的网络流量也解决不了这个问题,.如果T毕竟运输时间. 为此.我们可以基于时间分割点,所有的点将被分割为T点. 对于每一个点,下一次甚至一个容量为本人INF边缘 ...
- 网站的SEO以及它和站长工具的之间秘密(转)
博客迁移没有注意 URL 地址的变化,导致百度和 google 这两只爬虫引擎短时间内找不到路.近段时间研究了下国内最大搜索引擎百度和国际最大搜索引擎google的站长工具,说下感受. 百度的站长工具 ...
- PHP MVC自己主动RBAC自己主动生成的访问路由
使用的关键点: ReflectionClass class Rbac extends MY_Controller { public function index() { $arr = glob( __ ...