如何做以下面具输入问题?

时间:2010-11-17 19:18:17

标签: javascript jquery jquery-plugins

我有一个掩盖文本框的脚本,就在这里

<script src="http://jquery-joshbush.googlecode.com/
files/jquery.maskedinput-1.2.2.min.js" type="text/javascript"></script>
<script type="text/javascript">
jQuery(function($) {

      $('#j').mask('99:99');
         });
</script>

我还有一个脚本,可以在我点击按钮时动态添加文本框

<script type="text/javascript">
    function addRow(tableID) {

                var table = document.getElementById(tableID);

                var rowCount = table.rows.length;
                var row = table.insertRow(rowCount);

                var colCount = table.rows[0].cells.length;

                for(var i=0; i<colCount; i++) {

                    var newcell = row.insertCell(i);

                    newcell.innerHTML = table.rows[0].cells[i].innerHTML;
                    //alert(newcell.childNodes);
                    switch(newcell.childNodes[0].type) {
                        case "text":
                                newcell.childNodes[0].value = "";
                                newcell.childNodes[0].id="j";
                                alert(newcell.childNodes[0].id);
                                break;
                        case "checkbox":
                                newcell.childNodes[0].checked = false;
                                break;
                        case "select-one":
                                newcell.childNodes[0].selectedIndex = 0;
                                break;
                    }
                }
            }

            function deleteRow(tableID) {
                try {
                var table = document.getElementById(tableID);
                var rowCount = table.rows.length;

                for(var i=0; i<rowCount; i++) {
                    var row = table.rows[i];
                    var chkbox = row.cells[0].childNodes[0];
                    if(null != chkbox &amp;&amp; true == chkbox.checked) {
                        if(rowCount <= 1) {
                            alert("Cannot delete all the rows.");
                            break;
                        }
                        table.deleteRow(i);
                        rowCount--;
                        i--;
                    }


                }
                }catch(e) {
                    alert(e);
                }
            }
    </script>

我的输入框是

<INPUT type="text" name="STime[]" id="j"/>
<INPUT type="text" name="ETime[]" id="j"/>

我现在面临的问题是,第一个文本框将有一个蒙版结构,但在我使用j脚本动态添加文本框之后,我不会将文本框视为蒙版?为什么?我做错了什么?

5 个答案:

答案 0 :(得分:18)

使用类创建绑定到输入的事件(如果不需要,请不要使用ID)。使用jQuery .on方法http://api.jquery.com/on/

示例:

<input class="classSelector" />

<script>  
  $(document).on("focus", "classSelector", function() { 
    $(this).mask("99:99");
  });
</script>

您可以动态创建所需数量的输入,并使用on事件绑定来屏蔽它们。您创建的该类的每个新输入都将附加到该事件处理程序。

答案 1 :(得分:4)

使用livequery plug-in。 然后给出你想要掩盖类maskme的所有元素。现在你可以做到:

$(".maskme").livequery(function(){
    $(this).mask('99:99');
});

这将屏蔽即使在首次运行代码后添加的输入。

答案 2 :(得分:3)

首先不要在输入上使用ID

<input type="text" name="STime[]" class="jClass"/>

第二,如果您使用jQuery然后使用它。这更容易阅读。

<script type="text/javascript">
    function addRow(tableID) {
      var table = $("#" + tableID); //get the table
      var firstRowClone = $("tr:first", table).clone(); //clone the first row
      $("input:checkbox",firstRowClone).attr("checked", false);  // set all checkboxes to unchecked
      $("select", firstRowClone).each(function () { //Set all select lists to select first item
        this.selectedIndex = 0;
      }
      table.append(firstRowClone); //append the cloned row to the table.
      $("input:text", firstRowClone).val("").mask("99:99"); //set all input type="text" with value of "" and sets the mask on the clone.

    });

    function deleteRow(tableID) {
      $("#" + tableId + " tr:not(:eq(0))").remove(); //Remove all rows except the first row.         
    }


    $(document).ready(function {
      $('.jClass').mask('99:99'); //sets the mask on any rows loaded initially
    });

</script>

答案 3 :(得分:0)

掩码插件没有绑定到DOM中的新元素,而是绑定到$('#j')选择器中当时存在的元素。

  1. 使用类而不是ID(因为您无法在页面上合法地拥有两个具有相同ID的元素),并且
  2. 如有必要,请在添加到DOM后,在动态创建的元素上重新调用.mask()

答案 4 :(得分:0)

不要在脚本中使用ID use类来在php中使用multipal使用时间掩码 ghj