栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

您可以从ap:ajax监听器更新h:outputLabel吗?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

您可以从ap:ajax监听器更新h:outputLabel吗?

您无法更新未呈现的元素,

rendered=false
“这是JSF的方式”,以从DOM树中删除元素,

它不像css

display:none
visibility:hidden
<-这两个将元素保留在DOM树中,但是被隐藏,而JSF
rendered=false
甚至不会渲染(保留)DOM树中的元素(您甚至不会在页面的“查看源代码”中看到它) )

因此,在这种情况下,您需要

outputLabel
使用`panelGroup’包装并更新包装器的ID

<h:panelGroup id="periodLabelWrapper">    <h:outputLabel for="period" value="Period" id="periodLabel" rendered="#{ppBacker.periodRendered}"></h:panelGroup>

并参考

<p:ajax
update
属性中的包装器ID(始终在DOM树中),如下所示:

<p:ajax process=":addProgram:addProgramTo" update=":addProgram:periodGrid, :addProgram:periodLabelWrapper" event="change" listener="#{ppBacker.addProgramListener}" />

另一个解决方案是像这样更新整个表格

<p:ajax update="@form" ...
,这样您就不需要换行了
outputLabel

关于您的评论问题

@form如何更新未渲染的元素,但是直接通过id定位它们却没有呢?

您无法定位

update
页面中不存在的元素(rendered = false)“不存在”

但是,当您使用

update="@form"
update="someWrapperID"
表单/包装器“重新评估”它的所有内部元素时,包括带有
rendered="#{someBean.someCondition}"
和条件的那些内部元素都将被“重新评估”,因此如果结果
true
显示到要素中,则会显示…



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/427310.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号