我目前有一个显示数据库数据的数据表。我正在尝试为用户添加一种方法来编辑数据表的当前行(在数据表本身内部,没有外部表单或按钮),然后将其提交给支持bean,然后更新数据库。
我有一些条件渲染,允许用户按下特定行上的编辑按钮,并将输出文本更改为输入文本框,供他们编辑。
一般看:
inputText1 inputText2 inputText3(保存按钮)
我遇到的问题是,除非用户手动点击每个inputText上的返回值,否则bean中的值不会更新。除了调用数据库更新方法之外,保存按钮似乎没有做任何事情,而是使用表中的原始(未更新)数据。我已经工作了几个小时,似乎无法取得任何进展。
如果有人能指出我正确的方向,我会非常感激。基本上我想要的是每行中的一个按钮(保存),它将捕获用户在框中键入的值。
示例代码:
<h:dataTable id="dt1" value="#{Results.players}" var= "item" bgcolor="#F1F1F1" border="10" cellpadding="5" cellspacing="3">
<h:column>
<f:facet name="header"><h:outputText value="ID"/></f:facet>
<h:outputText value="#{item.id}"/>
</h:column>
<h:column>
<f:facet name="header">
<h:outputText value="Name"/>
</f:facet>
<h:outputText value="#{item.name}" rendered="#{not item.editable}"/>
<h:form>
<h:inputText value="#{Results.currentName}" rendered="#{item.editable}" immediate="true"/>
</h:form>
</h:column>
<h:column>
<f:facet name="header">
<h:outputText value="Department"/>
</f:facet>
<h:outputText value="#{item.department}" rendered="#{not item.editable}"/>
<h:inputText value="#{Results.currentDepartment}" rendered="#{item.editable}" immediate="true"/>
</h:column>
按钮。编辑将正常显示,单击时将显示“保存”按钮,该行将呈现为输入文本。
<h:column>
<f:facet name="header">
<h:outputText value="Edit"/>
</f:facet>
<h:form>
<h:commandLink value="Edit" rendered="#{not item.editable}" action="#{Results.editPlayers(item)}"/>
<h:commandLink value="Save" rendered="#{item.editable}" action="#{DBupdate.updatePlayers(item)}"/>
</h:form>
</h:column>
答案 0 :(得分:0)
在这些情况下更常见的一个问题是不更新屏幕字段,强制jsf更新字段的一种方法如下:
<h:commandLink ..>
<f:ajax event="click" render="@all" execute="@this" />
</h:commandLink>
或者
<h:commandLink ..>
<f:ajax render="@all" execute="@form" />
</h:commandLink>
此致