加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

重复ID. JSF

发布时间:2020-12-16 02:54:56 所属栏目:百科 来源:网络整理
导读:我有JSF的问题.任何人都可以说为什么这不起作用? h:selectOneListbox id="lang" size="5" value="#{MbInstitution.node.lang}" valueChangeListener="#{MbInstitution.changeLanguage}" rendered="#{MbInstitution.view}" a4j:support event="onchange" reR
我有JSF的问题.任何人都可以说为什么这不起作用?

<h:selectOneListbox
  id="lang" size="5"
  value="#{MbInstitution.node.lang}"
  valueChangeListener="#{MbInstitution.changeLanguage}"
  rendered="#{MbInstitution.view}"
  >
 <a4j:support event="onchange" reRender="shortDesc,fullDesc"/>
 <f:selectItems value="#{MbInstitution.languagesByInstitute}"/>
</h:selectOneListbox>
<h:selectOneListbox
  id="lang" size="5"
  disabled="#{!MbInstitution.managingNew}"
  value="#{MbInstitution.node.lang}"
  rendered="#{!MbInstitution.view}"
  >
 <f:selectItems value="#{MbInstitution.availableLanguages}"/>
</h:selectOneListbox>

它说:“组件instForm的重复Id:lang”
我知道我有2个具有相同Id的元素,但只有当另一个不是时,才会渲染一个元素.所以,我认为这不是一个问题.实际上它根本不是一个大问题,因为我不需要这个id,但如果我需要那么我该怎么办?

解决方法

您的问题是这两个组件是此页面的JSF组件树的一部分.即使它们无法同时显示,它们也会共享相同的ID,这是JSF不允许的.

我看到三种解决方案来解决您的问题:

第一种解决方案:定义两个不同的ID

第二种解决方案:正如Wayne Young所解释的,您可以使用NamingContainer,它将使用NamingContainer的ID为其ID添加前缀.

第三种解决方案:仅使用一个< h:selectOneListbox />然后在Java代码中做出改变.

<h:selectOneListbox id="lang" size="5" disabled="#{!MbInstitution.managingNew}" value="#{MbInstitution.node.lang}" valueChangeListener="#{MbInstitution.changeLanguage}">
    <a4j:support event="onchange" reRender="shortDesc,fullDesc" rendered="#{MbInstitution.view}"/>
    <f:selectItems value="#{MbInstitution.languages}"/>
</h:selectOneListbox>

Java代码:

public List<SelectItem> getLanguage() {
    if (isView()) {
        return getLanguagesByInstitute();
    } else {
        return getAvailableLanguages();
    }
}

public void changeLanguage(ValueChangeEvent evt) {
    if (!isView()) {
        return;
    }
    ...
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读