1

我的页面中有一个名为“BenefitsValue”的 div,显示设置为无。

<input id="Radio1" type="radio" name="bunit" value="1" onclick="onSample1()" 
       runat="server"/>Sample1
<input id="Radio2" type="radio" name="bunit" value="2" onclick="onSample2()" 
       runat="server"/>Sample2
<div id="BenefitsValue" style="display:none">
     <table id="approverTable">
          <tr id="rowtr" align="center">
              <td>
                 <input type="text" id="From" size="11" maxlength="9" 
                        class="gov-textbox" style="width: 100px;" />
               </td>
               <td>
                  <a id="addRangeLink" class="addRange" href="javascript:;" 
                     onclick="AddTextBox();">AddRange</a> 
               </td>
          </tr>
    </table>
 </div>

我将通过单击 AddRange 动态添加多个文本框。

function AddRange() {
    var val = "";
    var oTable = document.getElementById('approverTable');
    var rowCount = oTable.rows.length;
    var row = oTable.insertRow(rowCount);
    var cell0 = row.insertCell(0);
    var innerhtml;
    cell0.innerHTML = '<input type="text" id="From' + rowCount
        + '"  size="11" maxlength="9" class="gov-textbox" style="width: 100px;" />';
    }

如果我选择radiobutton1我将显示内容,我将通过单击 AddRange...div动态添加多个。textboxes

然后,一旦我选择radiobutton2它必须清除该textboxesdiv 的新添加并只显示我text box在 div 中指定的单个 ..

我曾经$("#BenefitsValue").empty();清除过内容,但是如果我再使用$("#BenefitsValue").show()它再次显示它,它什么也不显示...

如何克服它?

4

4 回答 4

1

只需在单选按钮更改中进行回发。所以它会清除 JavaScript 添加的内容,并将默认内容添加到页面中。

或者为动态内容添加一个不同的类并按类名删除它们。

$('dynamic-class').remove();
于 2013-04-18T11:51:37.823 回答
1

这个怎么样?

Live Demo

JS

function AddRange() {
    var val = "";

    var oTable = document.getElementById('approverTable');

    var rowCount = oTable.rows.length;
    var row = oTable.insertRow(rowCount);
    row.className='dynamic';
    var cell0 = row.insertCell(0);
     var innerhtml;
    cell0.innerHTML = '<input type="text" id="From' + rowCount + '"  size="11" maxlength="9" class="gov-textbox" style="width: 100px;" />';
}

function onSample1(){
    $('#BenefitsValue').show();    
}

function onSample2(){
    $('.dynamic').remove();
}

HTML

<input id="Radio1" type="radio" name="bunit" value="1" onclick="onSample1()" runat="server"/>Sample1
<input id="Radio2" type="radio" name="bunit" value="2" onclick="onSample2()" runat="server"/>Sample2

<div id="BenefitsValue" style="display:none">
    <table id="approverTable">
        <tr id="rowtr" align="center">
            <td>
                <input type="text" id="From" size="11" maxlength="9" class="gov-textbox"                                         style="width: 100px;" />
            </td>
            <td>
                <a id="addRangeLink" class="addRange" href="javascript:;" onclick="AddRange();">AddRange</a> 
            </td>
        </tr>
    </table>
</div>
于 2013-04-18T12:04:19.273 回答
0

您是否试图从视图中隐藏元素?

$("#BenefitsValue").empty();

删除内容。相反,使用

$("#BenefitsValue").hide();

然后你可以.show()用来把它带回来

于 2013-04-18T11:51:06.343 回答
0

<div>您需要为动态添加的文本框创建不同的文本框。例如:

<table id="approverTable">
      <tr id="rowtr" align="center">
          <td>
             <input type="text" id="From" size="11" maxlength="9" 
                    class="gov-textbox" style="width: 100px;" />
           </td>
           <td>
              <a id="addRangeLink" class="addRange" href="javascript:;" 
                 onclick="AddTextBox();">AddRange</a> 
           </td>
           <td>
               <div id="dynamicallyAddedTextBoxesGoHere">
               </div>
           </td>
      </tr>
</table>

将您的文本框添加到$("#dynamicallyAddedTextBoxesGoHere"). 然后在您的 javascript 中,您可以显示/隐藏此 div -

$("#dynamicallyAddedTextBoxesGoHere").hide();

$("#dynamicallyAddedTextBoxesGoHere").show();
于 2013-04-18T11:54:39.503 回答