Подтвердить что ты не робот

Представление if-elseif-else в EL с использованием JSF

Следующий код JSF содержит два отдельных <c:if></c:if>. Давайте посмотрим на это.

<?xml version='1.0' encoding='UTF-8' ?>
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:c="http://java.sun.com/jsp/jstl/core">
    <h:head>
        <title>JSF EL</title>
    </h:head>
    <h:body>
        <h:form>

            <c:set scope="request" var="row" property="x" value="10"/>

            <c:if test="#{row==10}">
                <h:outputLabel value="value = 10"/>
            </c:if>

            <c:if test="#{row==15}">
                <h:outputLabel value="value = 15"/>
            </c:if>

        </h:form>
    </h:body>
</html>

Он просто отображает value = 10 на странице JSF во время выполнения. Мне нужно представить те же самые <c:if></c:if> со следующим if-elseif-else (контекст Java).

if(row.equals(10))
{
    //Do something...(JSF stuff)
}
else if(row.equals(15))
{
    //Do something...(JSF stuff)
}
else
{
    //Do something...(JSF stuff)
}

Как его можно представить с помощью языка выражений (EL) с помощью JSF?

4b9b3361

Ответ 2

Вы можете использовать EL, если хотите работать как IF:

<h:outputLabel value="#{row==10? '10' : '15'}"/>

Изменение стилей или классов:

style="#{test eq testMB.test? 'font-weight:bold' : 'font-weight:normal'}"

class="#{test eq testMB.test? 'divRred' : 'divGreen'}"

Ответ 3

Вы можете использовать "ELSE IF", используя условный оператор в языке выражений, как показано ниже:

 <p:outputLabel value="#{transaction.status.equals('PNDNG')?'Pending':
                                     transaction.status.equals('RJCTD')?'Rejected':
                                     transaction.status.equals('CNFRMD')?'Confirmed':
                                     transaction.status.equals('PSTD')?'Posted':''}"/>

Ответ 4

Одно из возможных решений:

<h:panelGroup rendered="#{bean.row == 10}">
    <div class="text-success">
        <h:outputText value="#{bean.row}"/>
    </div>
</h:panelGroup>