使用Javascript获取支持bean值

Öme*_*alı 13 javascript jsf jsf-2

JSF 2.0,Mojarra 2.0.1,PrimeFaces 3.4.1

有类似的问题,但我需要...... 其他; javascript函数必须等待支持bean方法,它正在填充想要从js函数中提取的变量.我想说的是:

<p:commandLink action="#{statusBean.getStatuses}" oncomplete="afterLoad()"/>
Run Code Online (Sandbox Code Playgroud)

假设js只是获取值并将其打印到屏幕上.

function afterLoad() {    
    alert("#{statusBean.size}");
}
Run Code Online (Sandbox Code Playgroud)

这是生日小子:

@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
}
Run Code Online (Sandbox Code Playgroud)

因此函数将大小警告为0,这是它的初始值,而我们期望看到3.

它是如何工作的:如果我将@PostConstruct注释添加到bean的头部肯定会得到正确的大小,因为bean已经在页面加载之前构造.但这意味着冗余进程,在commandlink操作之后只需要值.那么如何推迟js功能呢?有任何想法吗?

Bal*_*usC 24

JSF/EL和HTML/JS不同步运行.相反,JSF/EL在webserver中运行并生成HTML/JS,而HTML/JS又在webbrowser中运行.在浏览器中打开页面,右键单击并查看源代码.你看,没有一行JSF/EL.它是一个和所有HTML/JS.代替你的JS函数,你会看到:

function afterLoad() {    
    alert("0");
}
Run Code Online (Sandbox Code Playgroud)

确切地说,在完成命令按钮操作时会调用此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>
Run Code Online (Sandbox Code Playgroud)

根据您没有说明的具体功能要求,可能会有更优雅的方式.例如,RequestContext#execute(),<o:onloadScript>等.

  • 这是一个老线程..但我有一个问题..如果我使用外部JavaScript文件如何实现这一点?请帮帮我. (2认同)

par*_*lov 11

您的JavaScript中的EL是在呈现页面时计算的,您可以更新其容器(如果它在某个JSF组件中),但我建议采用另一种方法.

在进行AJAX请求时,可以在getStatuses()方法中添加回调参数.您可以使用Primefaces的RequestContext实用方法addCallBackParam():

public void getStatuses() {
    this.panelList = fillList();
    this.size = panelList.size();
    RequestContext.getCurrentInstance().addCallBackParam("size", this.size);
}
Run Code Online (Sandbox Code Playgroud)

你可以在xhtml中使用这个参数:

<p:commandLink action="#{statusBean.getStatuses}" oncomplete="afterLoad(xhr, status, args)"/>

<script type="text/javascript">
  function afterLoad(xhr, status, args) {    
    alert(args.size);
  }
</script>
Run Code Online (Sandbox Code Playgroud)