在每个复选框的同一行中显示和隐藏文本字段
Show and hide the text field in the same row for each checkbox
在我的 jsp 中,我从 database.Now 创建了动态复选框 我想在同一行中为每个检查显示和隐藏文本字段 box.tell 我可能 ways.I 尝试使用一些 java 脚本和 jquery 但文本字段仅用于第一个复选框。
function Checkbox(){
if(document.getElementById('select').checked){
document.getElementById('test').style.display='block';
document.getElementById('test1').style.display='block';
}else{
document.getElementById('test').style.display='none';
document.getElementById('test1').style.display='none';
}
}
<table>
<c:if test="${empty PAStranslist || PASEditValue == null}">
<c:if test="${!empty assetsList}">
<c:forEach items="${assetsList}" var="assetsList" varStatus="loop">
<tr>
<td width="18%" class="thlabel"><c:out value='${assetsList.asset}'/></td>
<%-- <c:if test="${assetsList.selectedCheckBox == 'true'}"> --%>
<td width="32%"><form:checkbox path="selectedCheckBox" name ="select" value="${assetsList.id}" id="select" onclick="Checkbox();"/></td>
<td width="18%" class="thlabel" style="display: none" id="test">Asset Code</td>
<td width="32%" style="display: none" id="test1" ><form:input path="assetCode" maxlength="20" onkeyup="check(this, '20');"></form:input>
<%-- </c:if> --%>
</tr>
</c:forEach>
</c:if>
<c:if test="${empty assetsList}">
<tr><td style="color: red">No physical assets to display</td></tr>
</c:if>
</c:if>
</table>
您需要在 forEach 迭代器中唯一标识每一行数据,以便您可以分别引用每一行。
根据当前行索引分配唯一ID,如:
<td width="32%" style="display: none" id="test1_<c:out value='${loop.index}'/>" >
然后将javascript函数改为:
function Checkbox(index){
if(document.getElementById('select_'+index).checked){
document.getElementById('test_'+index).style.display='block';
document.getElementById('test1_'+index).style.display='block';
}else{
document.getElementById('test_'+index).style.display='none';
document.getElementById('test1_'+index).style.display='none';
}
}
您对该函数的调用将变为:
onclick="Checkbox('<c:out value="${loop.index}"/>');"
您可以更改 onclick
函数以使用当前对象:
onclick="Checkbox(this);"
然后使用原生JavaScript,在你的JS函数中,你可以这样做:
function Checkbox(obj){
if(obj.checked){
obj.parentNode.parentNode.getElementsByTagName('td')[2].style.display='block';
obj.parentNode.parentNode.getElementsByTagName('input')[0].style.display='block';
}else{
obj.parentNode.parentNode.getElementsByTagName('td')[2].style.display='none';
obj.parentNode.parentNode.getElementsByTagName('input')[0].style.display='none';
}
}
使用JQuery,您可以:
function Checkbox(obj){
if(obj.checked){
$(obj).closest('tr').find('#test').show();
$(obj).closest('tr').find('#test1').show();
}else{
$(obj).closest('tr').find('#test').hide();
$(obj).closest('tr').find('#test1').hide();
}
}
在我的 jsp 中,我从 database.Now 创建了动态复选框 我想在同一行中为每个检查显示和隐藏文本字段 box.tell 我可能 ways.I 尝试使用一些 java 脚本和 jquery 但文本字段仅用于第一个复选框。
function Checkbox(){
if(document.getElementById('select').checked){
document.getElementById('test').style.display='block';
document.getElementById('test1').style.display='block';
}else{
document.getElementById('test').style.display='none';
document.getElementById('test1').style.display='none';
}
}
<table>
<c:if test="${empty PAStranslist || PASEditValue == null}">
<c:if test="${!empty assetsList}">
<c:forEach items="${assetsList}" var="assetsList" varStatus="loop">
<tr>
<td width="18%" class="thlabel"><c:out value='${assetsList.asset}'/></td>
<%-- <c:if test="${assetsList.selectedCheckBox == 'true'}"> --%>
<td width="32%"><form:checkbox path="selectedCheckBox" name ="select" value="${assetsList.id}" id="select" onclick="Checkbox();"/></td>
<td width="18%" class="thlabel" style="display: none" id="test">Asset Code</td>
<td width="32%" style="display: none" id="test1" ><form:input path="assetCode" maxlength="20" onkeyup="check(this, '20');"></form:input>
<%-- </c:if> --%>
</tr>
</c:forEach>
</c:if>
<c:if test="${empty assetsList}">
<tr><td style="color: red">No physical assets to display</td></tr>
</c:if>
</c:if>
</table>
您需要在 forEach 迭代器中唯一标识每一行数据,以便您可以分别引用每一行。
根据当前行索引分配唯一ID,如:
<td width="32%" style="display: none" id="test1_<c:out value='${loop.index}'/>" >
然后将javascript函数改为:
function Checkbox(index){
if(document.getElementById('select_'+index).checked){
document.getElementById('test_'+index).style.display='block';
document.getElementById('test1_'+index).style.display='block';
}else{
document.getElementById('test_'+index).style.display='none';
document.getElementById('test1_'+index).style.display='none';
}
}
您对该函数的调用将变为:
onclick="Checkbox('<c:out value="${loop.index}"/>');"
您可以更改 onclick
函数以使用当前对象:
onclick="Checkbox(this);"
然后使用原生JavaScript,在你的JS函数中,你可以这样做:
function Checkbox(obj){
if(obj.checked){
obj.parentNode.parentNode.getElementsByTagName('td')[2].style.display='block';
obj.parentNode.parentNode.getElementsByTagName('input')[0].style.display='block';
}else{
obj.parentNode.parentNode.getElementsByTagName('td')[2].style.display='none';
obj.parentNode.parentNode.getElementsByTagName('input')[0].style.display='none';
}
}
使用JQuery,您可以:
function Checkbox(obj){
if(obj.checked){
$(obj).closest('tr').find('#test').show();
$(obj).closest('tr').find('#test1').show();
}else{
$(obj).closest('tr').find('#test').hide();
$(obj).closest('tr').find('#test1').hide();
}
}