我在我的 RADGrid 上启用了分组,但是当我拖放一列时,我看到的只是拖动时的“CrossHair”光标。我没有看到动画在视觉上显示代表被拖动的列的框,也没有看到出现的“双箭头”向您显示列即将被删除的位置。我在 Telerik RADGrid 演示中看到了这两个功能,但我似乎可以在我自己的 RADGrid 上复制此功能。
帮助!
我在我的 RADGrid 上启用了分组,但是当我拖放一列时,我看到的只是拖动时的“CrossHair”光标。我没有看到动画在视觉上显示代表被拖动的列的框,也没有看到出现的“双箭头”向您显示列即将被删除的位置。我在 Telerik RADGrid 演示中看到了这两个功能,但我似乎可以在我自己的 RADGrid 上复制此功能。
帮助!
试试下面的链接。这将帮助您使拖放工作。我目前也在使用这种方法。我的 DNN 是 6.x 版
*编辑:在您的 Page_Load 中调用以下方法(这只是为了在页面上动态获取脚本块。您也必须执行我链接中描述的步骤):
public void subDragDropJavaScript()
{
// define the script string to add to the page
StringBuilder sJavaScript = new StringBuilder();
// js header
sJavaScript.Append(("<script type=\'text/javascript\'>" + "\r\n"));
sJavaScript.Append("function startRowDrag_ModuleID_"+ this.ModuleId + "_GridID_" + oDNNGrid.ID + "(row, args)" + "\r\n");
sJavaScript.Append("{" + "\r\n");
sJavaScript.Append("var target = args.target || args.srcElement;" + "\r\n");
sJavaScript.Append("if (target.className.indexOf('rgDrag') > -1)" + "\r\n");
sJavaScript.Append("{" + "\r\n");
sJavaScript.Append("args._isDragHandle = true;" + "\r\n");
sJavaScript.Append("var tableView = $find(row.id.split('__')[0]);" + "\r\n");
sJavaScript.Append("var grid = $find(tableView.get_owner().get_id());" + "\r\n");
sJavaScript.Append("tableView.get_dataItems();" + "\r\n");
sJavaScript.Append("$find(row.id).set_selected(true);" + "\r\n");
sJavaScript.Append("var origFunc = Telerik.Web.UI.RadGrid.prototype._canRiseRowEvent;" + "\r\n");
sJavaScript.Append("Telerik.Web.UI.RadGrid.prototype._canRiseRowEvent = function ()" + "\r\n");
sJavaScript.Append("{" + "\r\n");
sJavaScript.Append("var el = arguments[0].target || arguments[0].srcElement;" + "\r\n");
sJavaScript.Append("return origFunc.apply(grid, arguments) || el.tagName.toLowerCase() == 'img';" + "\r\n");
sJavaScript.Append("}" + "\r\n");
sJavaScript.Append("grid._mouseDown(args);" + "\r\n");
sJavaScript.Append("Telerik.Web.UI.RadGrid.prototype._canRiseRowEvent = origFunc;" + "\r\n");
sJavaScript.Append("}" + "\r\n");
sJavaScript.Append("}" + "\r\n");
sJavaScript.Append("function gridRowDragStarted_ModuleID_" + this.ModuleId + "_GridID_" + oDNNGrid.ID + "(sender, args) {" + "\r\n");
sJavaScript.Append("if (!args.get_domEvent()._isDragHandle) {" + "\r\n");
sJavaScript.Append("args.set_cancel(true);" + "\r\n");
sJavaScript.Append("}" + "\r\n");
sJavaScript.Append("}" + "\r\n");
// js close block
sJavaScript.Append("</script>");
// add js block to page
this.Page.ClientScript.RegisterStartupScript(typeof(string), "DragnDropRowSelection_" + ModuleId, sJavaScript.ToString());
}
最好的问候,没有人
我知道这是一个旧线程,但我最近才找到答案。
在我的自定义模块的 Module.css 中,我添加了以下代码:
.RadGrid
{
z-index: 1000;
}
显然 DNN 框架的 default.css 使模块的 z-index 高于网格,从而掩盖了动画。将 z-index 增加到网格本身会将其置于模块上方,从而允许动画再次显示。