このような通常の状況では:
<h:form>
<h:selectOneRadio value="#{bean.gender}">
<f:selectItem itemValue="Male" itemLabel="Male" />
<f:selectItem itemValue="Female" itemLabel="Female" />
<f:selectItem itemValue="Other" itemLabel="Other" />
</h:selectOneRadio>
<h:commandButton value="Submit" action="#{bean.action}" />
</h:form>
1 つのラジオ ボタンを選択すると、もう 1 つのラジオ ボタンが選択解除され、ラジオ ボタンはポストバックで選択されたままになります。(同じビューがレンダリングされる場合)
ただし、 のような反復コンポーネントを扱っている場合<h:dataTable>
、選択は失われます。
スニペットを検討してください:
<h:form id="hashMapFormId">
<b>HASH MAP:</b>
<h:dataTable value="#{playersBean.dataHashMap.entrySet()}" var="t" border="1">
<h:column>
<f:facet name="header">Select</f:facet>
<h:selectOneRadio id="radiosId" onclick="deselectRadios(this.id);"
value="#{playersBean.select}">
<f:selectItem itemValue="null"/>
</h:selectOneRadio>
</h:column>
</h:dataTable>
<h:commandButton value="Show Hash Map Selection"
action="#{playersBean.showSelectedPlayer()}" />
</h:form>
シンプルな JavaScript で実装されている 1 つのラジオ ボタンが選択されているときに、他のラジオ ボタンの選択を解除すると、
function deselectRadios(id) {
var f = document.getElementById("hashMapFormId");
for (var i = 0; i < f.length; i++)
{
var e = f.elements[i];
var eid = e.id;
if (eid.indexOf("radiosId") !== -1) {
if (eid.indexOf(id) === -1) {
e.checked = false;
} else {
e.checked = true;
}
}
}
}
ポストバック時にラジオ ボタンが選択されていないことがわかります。この欠点を解決する方法は?
これは、このコンポーネント属性itemValue
がnull
次のとおりであるためであることをよく知っています。
<f:selectItem itemValue="null"/>