- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 primefaces dataTable 和 rowEdit 事件来更改和保存我的 dataTable 中的值。当我编辑未过滤的行值时,效果很好,但当我过滤值并尝试编辑时,编辑了错误的 ID。
例如:我有一个包含 5 条记录的列表,ID 范围从 1 到 5。
我过滤列表以显示 id = 5 的记录,因此它只显示一行。当我尝试编辑此记录时,我的 bean 正确获取了值,但对象的 ID 不是 5,而是 1,在我应用过滤器之前它位于数据表的第一行。如果我编辑过滤表的第二行,它会得到没有过滤器的原始数据表第二行的 ID。
屏幕:
<p:dataTable id="dataTable" var="linha" rowKey="#{linha.id}"
value="#{gestor.listaGestor}" editable="true"
draggableColumns="true"
rendered="#{not empty gestor.listaGestor}"
widgetVar="tableGestor" filteredValue="#{gestor.filteredGestor}"
emptyMessage="Não existem registros." resizableColumns="true" styleClass="datatable_cadastro" liveResize="true">
<f:facet name="header">
Tabela Gestores
<p:commandButton id="toggler" type="button" value="Colunas" />
<p:columnToggler datasource="dataTable" trigger="toggler" />
</f:facet>
<p:ajax event="rowEdit" listener="#{gestor.onRowEdit}"
update=":edicao:msgs,:edicao:dataTable" />
<p:ajax event="rowEditCancel" listener="#{gestor.onRowCancel}"
update=":edicao:msgs" />
<p:column headerText="ID" sortBy="#{linha.id}" filterBy="#{linha.id}"
style="width:50px;">
<p:outputLabel value="#{linha.id}" style="width:100%" />
</p:column>
<p:column headerText="NOME" filterBy="#{linha.nome}"
filterMatchMode="contains" sortBy="#{linha.nome}"
style="width:100%;">
<p:cellEditor>
<f:facet name="output">
<h:outputText value="#{linha.nome.trim()}" />
</f:facet>
<f:facet name="input">
<p:inputTextarea value="#{linha.nome}" id="nome"
update=":edicao" style="width:100%" />
</f:facet>
</p:cellEditor>
</p:column>
<p:column headerText="E-MAIL"
style="width:100%;" sortBy="#{linha.email}"
filterBy="#{linha.email}" filterMatchMode="contains">
<p:cellEditor>
<f:facet name="output">
<h:outputText value="#{linha.email.trim()}" />
</f:facet>
<f:facet name="input">
<p:inputTextarea value="#{linha.email}" id="email"
update=":edicao" />
</f:facet>
</p:cellEditor>
</p:column>
<p:column headerText="ATIVO" style="width:150px;" filterBy="#{linha.ativo}" filterMatchMode="equals">
<f:facet name="filter">
<p:selectOneMenu onchange="PF('tableGestor').filter()" >
<f:converter converterId="javax.faces.Character"/>
<f:selectItem itemLabel="TODOS" itemValue=""/>
<f:selectItem itemLabel="ATIVO" itemValue="T"/>
<f:selectItem itemLabel="INATIVO" itemValue="F"/>
</p:selectOneMenu>
</f:facet>
<p:cellEditor>
<f:facet name="output">
<p:selectBooleanCheckbox value="#{gestor.charToBool(linha.ativo)}" disabled="true"/>
</f:facet>
<f:facet name="input">
<p:selectBooleanCheckbox value="#{gestor.ativo}" id="ativo" immediate="true" update=":edicao" style="width:100%;"/>
</f:facet>
</p:cellEditor>
</p:column>
<p:column headerText="!" style="width:40px">
<p:rowEditor/>
</p:column>
<p:column headerText="X" style="width:40px">
<p:commandLink styleClass="ui-icon ui-icon-trash"
action="#{gestor.deletar(linha)}" update=":edicao" />
</p:column>
</p:dataTable>
Bean(onRowEdit):
public void onRowEdit(RowEditEvent event){
Object value = event.getObject();
GestorVO gestorTela = (GestorVO) value;
SimpleDateFormat dataHora = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
FacesContext context = FacesContext.getCurrentInstance();
if(gestorTela.getId() != null){
if(ativo){
gestorTela.setAtivo('T');
} else {
gestorTela.setAtivo('F');
}
GestorRN gestorRN = new GestorRN();
GestorVO gestorAntes = gestorRN.getByPrimaryKey(gestorTela.getId());
/** CONSISTENCIA DOS CAMPOS */
/** IF CASO O CONTEUDO DOS CAMPOS SEJA NULO */
if (gestorTela.getNome().trim().isEmpty() || gestorTela.getEmail().trim().isEmpty() ) {
gestorTela.setNome(gestorAntes.getNome());
gestorTela.setEmail(gestorAntes.getEmail());
gestorTela.setAtivo(gestorAntes.getAtivo());
context.addMessage(null, new FacesMessage(FacesMessage.SEVERITY_INFO, "Alteração foi cancelada" ,"Nenhum campo pode estar vazio ou conter apenas espaço(s)." ));
} else {
/** IF CASO O CONTEUDO FOI SALVO MAS NÃO HOUVERAM ALTERAÇÕES NO REGISTRO */
if (gestorAntes.getNome().trim().equals(gestorTela.getNome().trim())
&& gestorAntes.getEmail().trim().equals(gestorTela.getEmail().trim())
&& gestorAntes.getAtivo() == gestorTela.getAtivo() ) {
gestorTela.setNome(gestorAntes.getNome());
gestorTela.setEmail(gestorAntes.getEmail());
gestorTela.setAtivo(gestorAntes.getAtivo());
context.addMessage(null, new FacesMessage(FacesMessage.SEVERITY_INFO, "Alteração foi cancelada" ,"Não houve alteração no registro" ));
}
/** CASO O CONTEUDO TENHA SIDO REALMENTE ALTERADO, SALVA O CONTEUDO */
else{
/** Realiza o trim para limpeza dos campos antes da gravação*/
gestorTela.setNome(gestorTela.getNome().trim());
gestorTela.setEmail(gestorTela.getEmail().trim());
gestorTela.setUsuarioAlteracao(loginRN.usuarioLogado().getNome());
gestorTela.setDataAlteracao(dataHora.format(new Date()));
/** Caso ocorra erros no método salvar, a tela retornará para os valores padrões antes da alteração */
boolean confirmacao = gestorRN.salvar(gestorTela);
if(!confirmacao) {
gestorTela.setNome(gestorAntes.getNome());
gestorTela.setEmail(gestorAntes.getEmail());
gestorTela.setAtivo(gestorAntes.getAtivo());
}
}
}
} else {
context.addMessage(null, new FacesMessage(FacesMessage.SEVERITY_INFO, "ID do objeto Gestor não identificado" ,"Não foi possível identificar o ID do Gestor selecionado. Informe o ocorrido ao administrador do sistema" ));
}
}
最佳答案
当我使用@requestScoped bean 时,这发生在我身上。我切换到 @ViewScoped 并且它工作正常。
关于jsf - rowEdit 在 dataTable Primefaces 上过滤行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30267451/
猫f1.txt阿曼维沙尔阿杰贾伊维杰拉胡尔曼尼什肖比特批评塔夫林现在输出应该符合上面给定的条件 最佳答案 您可以在文件读取循环中设置一个计数器并打印它, 计数=0 读取行时做 让我们数一数++ if
我正在尝试查找文件 1 和文件 2 中的共同行。如果公共(public)行存在,我想写入文件 2 中的行,否则打印文件 1 中的非公共(public)行。fin1 和 fin2 是这里的文件句柄。它读
我有这个 SQL 脚本: CREATE TABLE `table_1` ( `IDTable_1` int(11) NOT NULL, PRIMARY KEY (`IDTable_1`) );
我有 512 行要插入到数据库中。我想知道提交多个插入内容是否比提交一个大插入内容有任何优势。例如 1x 512 行插入 -- INSERT INTO mydb.mytable (id, phonen
如何从用户中选择user_id,SUB(row, row - 1),其中user_id=@userid我的表用户,id 为 1、3、4、10、11、23...(不是++) --id---------u
我曾尝试四处寻找解决此问题的最佳方法,但我找不到此类问题的任何先前示例。 我正在构建一个基于超本地化的互联网购物中心,该区域分为大约 3000 个区域。每个区域包含大约 300 个项目。它们是相似的项
preg_match('|phpVersion = (.*)\n|',$wampConfFileContents,$result); $phpVersion = str_replace('"','',
我正在尝试创建一个正则表达式,使用“搜索并替换全部”删除 200 个 txt 文件的第一行和最后 10 行 我尝试 (\s*^(\h*\S.*)){10} 删除包含的前 10 行空白,但效果不佳。 最
下面的代码从数据库中获取我需要的信息,但没有打印出所有信息。首先,我知道它从表中获取了所有正确的信息,因为我已经在 sql Developer 中尝试过查询。 public static void m
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我试图在两个表中插入记录,但出现异常。您能帮我解决这个问题吗? 首先我尝试了下面的代码。 await _testRepository.InsertAsync(test); await _xyzRepo
这个基本的 bootstrap CSS 显示 1 行 4 列: Text Text Text
如果我想从表中检索前 10 行,我将使用以下代码: SELECT * FROM Persons LIMIT 10 我想知道的是如何检索前 10 个结果之后的 10 个结果。 如果我在下面执行这段代码,
今天我开始使用 JexcelApi 并遇到了这个:当您尝试从特定位置获取元素时,不是像您通常期望的那样使用sheet.getCell(row,col),而是使用sheet.getCell(col,ro
我正在尝试在我的网站上开发一个用户个人资料系统,其中包含用户之前发布的 3 个帖子。我可以让它选择前 3 条记录,但它只会显示其中一条。我是不是因为凌晨 2 点就想编码而变得愚蠢? query($q)
我在互联网上寻找答案,但找不到任何答案。 (我可能问错了?)我有一个看起来像这样的表: 我一直在使用查询: SELECT title, date, SUM(money) FROM payments W
我有以下查询,我想从数据库中获取 100 个项目,但 host_id 多次出现在 urls 表中,我想每个 host_id 从该表中最多获取 10 个唯一行。 select * from urls j
我的数据库表中有超过 500 行具有特定日期。 查询特定日期的行。 select * from msgtable where cdate='18/07/2012' 这将返回 500 行。 如何逐行查询
我想使用 sed 从某一行开始打印 n 行、跳过 n 行、打印 n 行等,直到文本文件结束。例如在第 4 行声明,打印 5-9,跳过 10-14,打印 15-19 等 来自文件 1 2 3 4 5 6
我目前正在执行验证过程来检查用户的旧密码,但问题是我无法理解为什么我的查询返回零行,而预期它有 1 行。另一件事是,即使我不将密码文本转换为 md5,哈希密码仍然得到正确的答案,但我不知道为什么会发生
我是一名优秀的程序员,十分优秀!