3

给定以下列表<p:selectOneRadio>

<p:selectOneRadio layout="grid" columns="1" value="#{1}">
    <f:selectItem id="paypal" itemValue="1" itemLabel="Paypal"/>
    <f:selectItem id="wireTransfer" itemValue="2" itemLabel="Wire Transfer"/>
</p:selectOneRadio>

是否可以将图像显示为标签,<f:selectItem>以便列表如下所示?

在此处输入图像描述

我尝试使用<p:outputLabel>放置一个<p:graphicImage>内部并从内部删除属性itemLabel,但无论哪种方式它都不起作用。<f:selectItem><p:selectOneRadio>

<p:outputLabel for="paypal">
    <p:graphicImage library="default" name="images/payments/paypal_logo.jpeg"/>
</p:outputLabel>
4

2 回答 2

4

您可以使用SelectOneRadio - 自定义布局来解决它

这里有一个例子:

<h3>Custom Layout</h3>
<p:outputPanel id="customPanel" style="margin-bottom:10px">
    <p:selectOneRadio id="customRadio" value="#{radioView.color}" layout="custom">
        <f:selectItem itemLabel="Red" itemValue="Red" />
        <f:selectItem itemLabel="Green" itemValue="Green" />
        <f:selectItem itemLabel="Blue" itemValue="Blue" />
    </p:selectOneRadio>

    <h:panelGrid columns="3" cellpadding="5">
        <p:radioButton id="opt1" for="customRadio" itemIndex="0" />
        <h:outputLabel for="opt1" value="Red" />
        <p:spinner />

        <p:radioButton id="opt2" for="customRadio" itemIndex="1" />
        <h:outputLabel for="opt2" value="Green" />
        <p:inputText />

        <p:radioButton id="opt3" for="customRadio" itemIndex="2" />
        <h:outputLabel for="opt3" value="Blue" />
        <p:calendar />
    </h:panelGrid>
</p:outputPanel>
于 2014-08-10T18:09:08.270 回答
0
<p:selectOneRadio id="customRadio" value="#{radioView.image}" layout="custom">
    <f:selectItem itemLabel="Image1" itemValue="Image1" />
    <f:selectItem itemLabel="Image2" itemValue="Image2" />
</p:selectOneRadio>
<h:panelGrid columns="2" cellpadding="5">
    <p:radioButton id="opt1" for="customRadio" itemIndex="0" />
    <h:graphicImage value="/some/image2.png"/>
    <p:radioButton id="opt2" for="customRadio" itemIndex="1" />
    <h:graphicImage value="/some/image2.png"/>
<h:panelGrid columns="3" cellpadding="5">
于 2019-06-20T03:22:14.310 回答