JSF 2.0、莫贾拉 2.0.1、PrimeFaces 3.4.1
有类似的问题,但我需要某物。别的; javascript函数必须等待backing bean方法,该方法正在填充想要从js函数中提取的变量。我想说的是:
<p:commandLink action="#{statusBean.getStatuses}" oncomplete="afterLoad()"/>
假设 js 函数只是获取值并将其打印到屏幕上。
function afterLoad() {
alert("#{statusBean.size}");
}
这是生日孩子:
@ManagedBean
@ViewScoped
public class StatusBean {
public int size=0;
List<Status> panelList = new ArrayList<Status>();
public void getStatuses() {
this.panelList = fillList();
this.size = panelList.size(); //Assuming 3
}
//getter and setters
}
因此函数将大小警告为 0,这是它的初始值,而我们期望看到 3。
它是如何工作的:如果我添加@PostConstruct
对 bean 头部进行注释肯定会获得正确的大小,因为 bean 已经在页面加载之前构建完毕。但这意味着冗余的进程,仅在命令链接操作后需要的值。那么如何推迟js功能呢?有任何想法吗?
JSF/EL 和 HTML/JS 不同步运行。相反,JSF/EL 在 Web 服务器中运行并生成 HTML/JS,而 HTML/JS 又在 Web 浏览器中运行。在浏览器中打开页面,右键单击查看源代码。您会看到,没有一行 JSF/EL。它完全是 HTML/JS。在 JS 函数的位置,您将看到:
function afterLoad() {
alert("0");
}
正是在命令按钮操作完成时调用这个 JS 函数。所以这个结果是完全可以预料到的。
基本上,您想让 JSF 重新渲染那段 JS。
<p:commandLink action="#{statusBean.getStatuses}" update="afterLoad" oncomplete="afterLoad()"/>
<h:panelGroup id="afterLoad">
<h:outputScript>
function afterLoad() {
alert("#{statusBean.size}");
}
</h:outputScript>
</h:panelGroup>
根据您没有透露的具体功能要求,可能有更优雅的方法。例如,RequestContext#execute()
, <o:onloadScript>
, etc.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)