Telerik 防止在模块选择DNN 9上重新加载页面
当我单击模块选择对话框内的模块时,DNN刷新页面(在页面上出现悬停的可拖动元素之前)。这只会发生在我们的皮肤上() DNN正在使用TeleriksTelerik 防止在模块选择DNN 9上重新加载页面,telerik,dotnetnuke,dotnetnuke-9,Telerik,Dotnetnuke,Dotnetnuke 9,当我单击模块选择对话框内的模块时,DNN刷新页面(在页面上出现悬停的可拖动元素之前)。这只会发生在我们的皮肤上() DNN正在使用TeleriksfindComponent方法查找元素#DNN\u ContentPane\u SyncPanel(似乎是ajax包装器)。由于找不到元素,DNN将执行页面重新加载 我们的皮肤内容窗格: <div id="ContentPane" runat="server" containertype="G" containername="Invisible
findComponent
方法查找元素#DNN\u ContentPane\u SyncPanel
(似乎是ajax包装器)。由于找不到元素,DNN将执行页面重新加载
我们的皮肤内容窗格:
<div id="ContentPane" runat="server" containertype="G" containername="Invisible Container" containersrc="default.ascx"></div>
过了一段时间,我们发现了问题所在。 我们的皮肤使用了
语法而不是
,这导致DNN强制重新加载。这可能与文档的生命周期有关
refreshPane: function (paneName, args, callback, callOnReload) {
var paneId;
if (!paneName) {
paneId = this.getModuleManager().getPane().attr('id');
} else {
paneId = this.getPaneById(paneName).attr('id');
}
var pane = $('#' + paneId);
var parentPane = pane.data('parentpane');
if (parentPane) {
this.refreshPane(parentPane, args, callback);
return;
}
//set module manager to current refresh pane.
this._moduleManager = pane.data('dnnModuleManager');
var ajaxPanel = $find(paneId + "_SyncPanel");
if (ajaxPanel) {
//remove action menus from DOM bbefore fresh pane.
var handler = this;
pane.find('div.DnnModule').each(function () {
var moduleId = handler._moduleManager._findModuleId($(this));
$('#moduleActions-' + moduleId).remove();
});
Sys.WebForms.PageRequestManager.getInstance().add_endRequest(this._refreshCompleteHandler);
this._refreshPaneId = paneId;
this._refreshCallback = callback;
ajaxPanel.ajaxRequest(args);
} else {
//save the args into cookie, after page reload then catch the cookie
//and float the module for drag
if (args && !this._noFloat) {
this._setCookie('CEM_CallbackData', args);
}
if (callOnReload && typeof callback == "function") {
callback.call($('#' + paneId), [true]);
}
location.reload();
}
}