have to press command button twice

2019-01-19 00:57发布

问题:

I'm working on building a web page and notice now that I have to press the command button twice. Any command button has the same problem, so I figured I would add and action listener on one of them to see if I could see something.

<h:form id="formP">
    <p:commandButton id="temp" value="photos" actionListener="#{viewBacking.debugBreakpoint()}" action="userPhoto" />
</h:form>

The backing bean has

public void debugBreakpoint() {
    int i = 0;
    i++;
}

Unfortunately, this does help. It hits my breakpoint only after the second press. I suspect that some field somewhere isn't passing validation but I would like some method of detecting what exactly is going wrong - why do I need the second push? Is there some option I can turn on in Glassfish, or something else where I can look at a dump of debug information? I can ignore the dump until everything is stable and then see what exactly is happening when I press the button for the first time.

Is there any such tool which I can use?

回答1:

That can happen when a parent component of the given <h:form> has been rendered/updated by another command button/link with <f:ajax>. The given form will then lose its view state which it would only get back after submitting the form for the first time. Any subsequent submits will then work the usual way. This is caused by a bug in JSF JS API as descibred in JSF issue 790 which is fixed in the upcoming JSF 2.2.

You need to fix the another command button/link with <f:ajax> to explicitly include the client ID of the given <h:form> in the render.

<f:ajax render=":somePanel :formP" />

Another way is to replace this <f:ajax> by a PrimeFaces <p:commandLink> or <p:commandButton> so that you don't need to explicitly include the client ID of all the forms. PrimeFaces's own JS API has namely already incorporated this fix.



回答2:

add event="onclick" in your p:commandbutton
I guess that will sort it out.



回答3:

or you can add this ajax="false" property in your commandButton

<p:commandButton ajax="false" action="#{userController.create}" value="#{bundle.CreateUserSaveLink}"></p:commandButton>


回答4:

I ran into the same issue. The solution was simple, instead of having both an actionListener and an action, just convert the actionListener method to return a string to where you want to navigate to and use it as the method for the action (and don't have an actionListener).

In simple terms: only use an action (do not use an actionListener on a commandButton that is submitting a form).



回答5:

Please check your binding with bean.

bean fields should be String or non primitive.