克隆Div和事件处理程序显示/隐藏

时间:2015-11-05 16:19:16

标签: javascript jquery html frontend

我克隆div #Play_Start并且在其下面我有隐藏/显示的事件,特别是在每个克隆的div中。但在克隆上只有第一个div事件有效。

事件:从下拉列表选择播放,Div隐藏。

我想要在每个div和同一克隆div中触发事件。

我的小提琴链接http://jsfiddle.net/kgm50e43/



var count = 1;

function clone() {
  if (count < 5) {
    $(this).parents("#Play_Start").clone()
      .appendTo("#Clone_Play")
      .on('click', 'button.clone', clone)
    count++;
  } else {}
}
$("button.clone").on("click", clone);

function InputDropDown() {
  var MainNav = $('#Inputs-Control').val();
  if (MainNav == 1) {
    alert('hi');
    $('#Play_Start').children('.IconTest').hide();
  };
}
&#13;
.clone {
  display: block;
  background-color: red;
  padding: 10px;
}
.clonedInput {
  position: relative;
  overflow: hidden;
}
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="Play_Start" class="col s12 l12 m12 First_sec clonedInput">
  <div class="col s3 l3 m3 input-field">
    <input type="text" id="tpOne" class="timepicker" placeholder="Start">
  </div>

  <div class="col s2 IconTest">
    asd
  </div>

  <div class="col s2 input-field">
    <select id="Inputs-Control" class="form-control" name="article()" onchange="InputDropDown();">
      <option value="0">Select</option>
      <option value="1">Play</option>
      <option value="2">Change</option>
      <option value="3">Pause</option>
      <option value="4">Stop</option>
      <option value="5">If</option>
    </select>
  </div>
  <div class="col s2 m2 l2">
    <button class="clone btn-floating btn-small waves-effect waves-light red counter_start_btn" onclick="clone();">
      <i class="material-icons">add</i>
    </button>

  </div>
  <div id="Clone_Play"></div>
&#13;
&#13;
&#13;

1 个答案:

答案 0 :(得分:0)

检查出来

https://jsfiddle.net/kgm50e43/1/

$(document).on('click', 'button.clone', clone);
$(document).on('change', '.form-control', function() {
    console.log($(this).val())
    var MainNav = $('.form-control').val();

    if (MainNav == 1) {
        alert('hi');
        $('#Play_Start').children('.IconTest').hide();
    };
});

这就是你需要的。

我在您的代码中发现的问题:

  

$(&#39;#输入 - 控制&#39)。VAL()

Id选择器只有在页面上有一个id时才会起作用,就像它应该的那样。如果不是,你应该使用课程。

  

$(document).on(&#39; change&#39;,&#39; .form-control&#39;

此外,您应该尝试绑定类似于上面的内容,我通常会遵循它,因为即使该元素将来也可用。

希望它有所帮助。