XPages 进度条未按预期使用服务器页面持久性设置 "keep pages in memory"
XPages progressbar not working as expected with server page persistence setting "keep pages in memory"
我想使用 Mark Leusnik(感谢他)非常好的 ProgressBar 实现。不幸的是,该实现对我不起作用。
经过一些调查,我找到了麻烦的原因:在我的 xpage 应用程序中,我有服务器页面持久性设置 keep pages in memory
。在 Mark Leusnik 的 Demo App 中,设置是 keep pages on disk
。我不知道为什么这个设置会影响进度条的运行时行为?
设置keep pages on disk
一切正常:
不幸的是没有设置 keep pages in memory
:
提前感谢您提供任何解决方案、解决方法或替代方案!
可行的解决方案(但是欢迎其他解决方案、想法等长 运行 代码进度条)
经过进一步调查,我找到了一个独立于服务器页面持久性设置的完美解决方案 (keep pages in memory/ keep pages on disk
)。
我的解决方案的关键点是为服务器端任务实施额外的 XAgent,而不是 运行 按钮 onClick-Event
内的代码。另外,这个XAgent会在进度条的启动例程中"started"(dojo.xhrGet
)
我对 Mark Leusnik 的 solution 进行了以下更改:
demo.xsp - XPage
<xp:button value="Start a (fake) long running process"
id="button1" dojoType="dijit.form.Button">
<xp:eventHandler event="onclick" submit="false">
<xp:this.script><![CDATA[xProgress.start();]]></xp:this.script>
</xp:eventHandler>
</xp:button>
xProgress - 脚本库 (CSJS)
start : function() {
this.targetNode = dojo.byId(this.targetNodeId);
if (this.targetNode==0) {
alert("Invalid target node specified for xProgress progress bar");
}
//setup the dijit progressbar
if (this.progressBar == null) {
this.progressBar = new dijit.ProgressBar(
{id: "myProgressBar", maximum: 100}, this.targetNode);
} else {
this.progressBar.update({
maximum: 100,
progress: 0
});
}
dojo.xhrGet({
url: window.location.href.substring(0,
window.location.href.indexOf(".nsf")+4) + "/export.xsp",
load: dojo.hitch(xProgress, "stop")
});
this.timerId = setInterval( dojo.hitch(xProgress, "update"), this.updateInterval);
},
export.xsp - XAgent(新的)
<?xml version="1.0" encoding="UTF-8"?>
<xp:view xmlns:xp="http://www.ibm.com/xsp/core" rendered="false">
<xp:this.afterRenderResponse><![CDATA[#{javascript: print("long running code started");
print( "browser: " + context.getUserAgent().getBrowser() + ",
remote IP: " + facesContext.getExternalContext().getRequest().getRemoteAddr());
updateProgress(0);
/*java.lang.Thread.sleep(750);
updateProgress(5);
java.lang.Thread.sleep(750);
updateProgress(10);
java.lang.Thread.sleep(750);
updateProgress(15);
java.lang.Thread.sleep(750);
updateProgress(20);
java.lang.Thread.sleep(750);
updateProgress(25);
java.lang.Thread.sleep(750);
updateProgress(30);
java.lang.Thread.sleep(2000);
updateProgress(50);
java.lang.Thread.sleep(1500);
updateProgress(60);
java.lang.Thread.sleep(1500);
updateProgress(75);
java.lang.Thread.sleep(1500);
updateProgress(80);
java.lang.Thread.sleep(1500);
updateProgress(90);
java.lang.Thread.sleep(1500);
updateProgress(100);*/
print("long running code stopped");
function updateProgress(to) {
progressPercentage = to;
synchronized(sessionScope) {
sessionScope.put("progress", to);
}
}}]]></xp:this.afterRenderResponse>
</xp:view>
我想使用 Mark Leusnik(感谢他)非常好的 ProgressBar 实现。不幸的是,该实现对我不起作用。
经过一些调查,我找到了麻烦的原因:在我的 xpage 应用程序中,我有服务器页面持久性设置 keep pages in memory
。在 Mark Leusnik 的 Demo App 中,设置是 keep pages on disk
。我不知道为什么这个设置会影响进度条的运行时行为?
设置keep pages on disk
一切正常:
不幸的是没有设置 keep pages in memory
:
提前感谢您提供任何解决方案、解决方法或替代方案!
可行的解决方案(但是欢迎其他解决方案、想法等长 运行 代码进度条)
经过进一步调查,我找到了一个独立于服务器页面持久性设置的完美解决方案 (keep pages in memory/ keep pages on disk
)。
我的解决方案的关键点是为服务器端任务实施额外的 XAgent,而不是 运行 按钮 onClick-Event
内的代码。另外,这个XAgent会在进度条的启动例程中"started"(dojo.xhrGet
)
我对 Mark Leusnik 的 solution 进行了以下更改:
demo.xsp - XPage
<xp:button value="Start a (fake) long running process"
id="button1" dojoType="dijit.form.Button">
<xp:eventHandler event="onclick" submit="false">
<xp:this.script><![CDATA[xProgress.start();]]></xp:this.script>
</xp:eventHandler>
</xp:button>
xProgress - 脚本库 (CSJS)
start : function() {
this.targetNode = dojo.byId(this.targetNodeId);
if (this.targetNode==0) {
alert("Invalid target node specified for xProgress progress bar");
}
//setup the dijit progressbar
if (this.progressBar == null) {
this.progressBar = new dijit.ProgressBar(
{id: "myProgressBar", maximum: 100}, this.targetNode);
} else {
this.progressBar.update({
maximum: 100,
progress: 0
});
}
dojo.xhrGet({
url: window.location.href.substring(0,
window.location.href.indexOf(".nsf")+4) + "/export.xsp",
load: dojo.hitch(xProgress, "stop")
});
this.timerId = setInterval( dojo.hitch(xProgress, "update"), this.updateInterval);
},
export.xsp - XAgent(新的)
<?xml version="1.0" encoding="UTF-8"?>
<xp:view xmlns:xp="http://www.ibm.com/xsp/core" rendered="false">
<xp:this.afterRenderResponse><![CDATA[#{javascript: print("long running code started");
print( "browser: " + context.getUserAgent().getBrowser() + ",
remote IP: " + facesContext.getExternalContext().getRequest().getRemoteAddr());
updateProgress(0);
/*java.lang.Thread.sleep(750);
updateProgress(5);
java.lang.Thread.sleep(750);
updateProgress(10);
java.lang.Thread.sleep(750);
updateProgress(15);
java.lang.Thread.sleep(750);
updateProgress(20);
java.lang.Thread.sleep(750);
updateProgress(25);
java.lang.Thread.sleep(750);
updateProgress(30);
java.lang.Thread.sleep(2000);
updateProgress(50);
java.lang.Thread.sleep(1500);
updateProgress(60);
java.lang.Thread.sleep(1500);
updateProgress(75);
java.lang.Thread.sleep(1500);
updateProgress(80);
java.lang.Thread.sleep(1500);
updateProgress(90);
java.lang.Thread.sleep(1500);
updateProgress(100);*/
print("long running code stopped");
function updateProgress(to) {
progressPercentage = to;
synchronized(sessionScope) {
sessionScope.put("progress", to);
}
}}]]></xp:this.afterRenderResponse>
</xp:view>