单击选项时的事件委托,不适用于克隆元素

如何解决单击选项时的事件委托,不适用于克隆元素

我之前的问题(已关闭)-> Jquery - Cloning a div which includes input unordered lists. How to get the dropdown to work in the cloned row?

有人提到了这个答案:-> Event binding on dynamically created elements?

我在尝试使用哪个静态祖先时遇到了困难,克隆版本不会记录任何点击。

例如,在我的第一个版本中,我使用 .on 如此...单击下拉列表中的一个选项来运行一个函数,该函数将分配一个选定的类,这将取消隐藏下一个下拉列表。

$(".option").on("click",unhideoption2);

但是对于我添加的每个父/静态选择器,它仍然没有记录对克隆版本的任何点击

例如

$(".optionlist").on("click",".option",unhideoption2);

$(".cselect").on("click",unhideoption2);

$(".row1").on("click",unhideoption2);

我是否应该将事件委托添加到被克隆的行而不是单个输入?尽管当我也尝试这样做时,它仍然没有记录对克隆行的点击。

$(".rows").on("click",'.clonerow',clonerow);

我在事件委托方面哪里出了问题?

https://jsfiddle.net/pfhnr9uk/4/

HTML

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="rows">
<div class="row1">
  <div class="cselect options1">
    <input type="text" disabled placeholder="Select n1">
    <ul class="optionlist">
      <li class="option option1">Business</li>
      <li class="option option2">Hair</li>
    </ul>
  </div>
<div class="cselect options2 hide">
    <input type="text" disabled placeholder="new test">
    <ul class="optionlist">
      <li class="option option1">test</li>
      <li class="option option2">option 2</li>
    </ul>
  </div>
</div>
<div class="row2">

  <div class="cselect options3">
    <input type="text" disabled placeholder="Select n2">
    <ul class="optionlist">
      <li class="option">Something</li>
      <li class="option">Else</li>
    </ul>
  </div>
</div>
<div class="clonerow">
click me
</div>
</div>

CSS

* {
  margin: 0;
  padding: 0;
}

/* ugly reset */

.cselect {
  position: relative;
}

.cselect input {
  background: #fff;
}

.cselect ul {
  display: none;
  position: absolute;
  z-index: 999;
  left: 0;
  top: 1.2rem;
  margin: 0;
  width: 100%;
  background: #fff;
  border: 1px solid #d6d6d6;
}

.cselect li {
  padding: 10px 5%;
  list-style: none;
}

.cselect li:hover {
  background: rgba(41,128,185,0.2);
}

.hide{
  display:none;
}

JS

$(function() { // DOM ready


  $(".cselect").each(function() {

    var $input = $(this).find("input");
    var $dropDown = $(this).find("ul");

    $(this).on("click",function() {
      $dropDown.stop().slideToggle();
    });

    $dropDown.on("click","li",function() {
      $input.val($(this).text());
    });

  });

});

var newnewid = 0;
var $cloneplayerclause = jQuery(".row1").clone(true);

function clonerow(){
  
  newnewid++;
  var $sectionClone = $cloneplayerclause.attr("id",newnewid).clone(true);
  $('.rows').append($sectionClone);
  
  
}

function unhideoption2(){
 $(".option").removeClass('selected');
 $(this).addClass('selected');
 if($('.option1').hasClass('selected')){
 $('.options2').removeClass('hide');
 }
 }

$(".option").on("click",unhideoption2);
$(".clonerow").on("click",clonerow);

解决方法

如何做到这一点的基本示例。

关键在这里:

function clonerow(){

        let cloneplayerclause = $(".row1").clone(false);

      let sectionClone = $(cloneplayerclause).attr("class","rowx").find(".cselect").each(function() {

        var $input = $(this).find("input");
        var $dropDown = $(this).find("ul");

        $(this).on("click",function() {
          $dropDown.stop().slideToggle();
        });

        $dropDown.on("click","li",function() {
          $input.val($(this).text());
        });

      });
      
      $('.rows').append(sectionClone);
      
      
    }

完整示例,尝试示例:

$(function(){


  $(".cselect").each(function(){

    var $input = $(this).find("input");
    var $dropDown = $(this).find("ul");

    $(this).on("click",function() {
      $dropDown.stop().slideToggle();
    });

    $dropDown.on("click",function() {
      $input.val($(this).text());
    });

  });
  
  let cloneplayerclause = $(".row1").clone(false);
  
  window.cloneplayerclause = cloneplayerclause;

});


function clonerow(){

    let sectionClone = $("<div class='rowx' />")
    
    $(cloneplayerclause).clone(true,true).find(".cselect").each(function(){

    var $input = $(this).find("input");
    var $dropDown = $(this).find("ul");

    $(this).on("click",function() {
      $input.val($(this).text());
    });
    
    $(sectionClone).append(this);

  });
  
  $('.rows').append(sectionClone);
  
  $(".option").on("click",unhideoption2);
  
}

function unhideoption2(){
 $(".option").removeClass('selected');
 $(this).addClass('selected');
 if($(this).parent().parent().parent().find('.options1 ul li').hasClass("selected")){
 $(this).parent().parent().parent().find('.options2').removeClass('hide');
 }
 }

$(".option").on("click",unhideoption2);
$(".clonerow").on("click",clonerow);
* {
  margin: 0;
  padding: 0;
}

/* ugly reset */

.cselect {
  position: relative;
}

.cselect input {
  background: #fff;
}

.cselect ul {
  display: none;
  position: absolute;
  z-index: 999;
  left: 0;
  top: 1.2rem;
  margin: 0;
  width: 100%;
  background: #fff;
  border: 1px solid #d6d6d6;
}

.cselect li {
  padding: 10px 5%;
  list-style: none;
}

.cselect li:hover {
  background: rgba(41,128,185,0.2);
}

.hide{
  display:none;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<html>

    <head>
    
        <script type="text/javascript" src="jquery-3.5.1.min.js"></script>
    
    </head>
    
    <body>
    
        <div class="rows">
        <div class="row1">
          <div class="cselect options1">
            <input type="text" disabled placeholder="Select n1">
            <ul>
              <li class="option option1">Business</li>
              <li class="option option2">Hair</li>
            </ul>
          </div>
        <div class="cselect options2 hide">
            <input type="text" disabled placeholder="new test">
            <ul>
              <li class="option option1">test</li>
              <li class="option option2">option 2</li>
            </ul>
          </div>
        </div>
        <div class="row2">

          <div class="cselect options3">
            <input type="text" disabled placeholder="Select n2">
            <ul>
              <li class="option">Something</li>
              <li class="option">Else</li>
            </ul>
          </div>
        </div>
        <div class="clonerow">
        click me
        </div>
        </div>

        <script type="text/javascript" src="index.js"></script>

    </body>

</html>

我在函数 unhideoption2 中使选项部分更加动态

if($(this).parent().parent().parent().find('.options1 ul li').hasClass("selected")){
 $(this).parent().parent().parent().find('.options2').removeClass('hide');
 }
,

事件处理程序不会被克隆,但您可以做的是在 .rows 框上创建事件处理程序,如下所示:

$(function() { // DOM ready
  const rows = $(".rows").on("click",function(e) {
    if (e.target.tagName == "INPUT") {
      const input = rows.find(e.target);
      input.parent().find("ul").stop().slideToggle();
    } else if (e.target.classList.contains("option")) {
      const li = e.target;
      const ul = li.parentNode;
      const divSelect = ul.parentNode;
      const row = divSelect.parentNode;
      const input = divSelect.querySelector("input");
      if (!divSelect.dataset.hidden)
        row.dataset.hidden = li.dataset.hidden;

      input.value = li.textContent;
      $(input).click();
      for(let i = 0; i < ul.children.length; i++)
      {
        ul.children[i].classList.toggle("selected",ul.children[i] === li);
      }
      const hiddenRows = row.querySelectorAll(".cselect[data-hidden]");
      for(let i = 0; i < hiddenRows.length; i++)
      {
        hiddenRows[i].classList.toggle("hide",!row.dataset.hidden || row.dataset.hidden != hiddenRows[i].dataset.hidden);
      }
    }
  });
});
var newnewid = 0;
var $cloneplayerclause = jQuery(".row1").clone(true);

function clonerow() {

  newnewid++;
  var $sectionClone = $cloneplayerclause.attr("id",newnewid).clone(true);
  $('.rows').append($sectionClone);


}

$(".clonerow").on("click",clonerow);
* {
  margin: 0;
  padding: 0;
}


/* ugly reset */

.cselect {
  position: relative;
}

.cselect input {
  background: #fff;
}

.cselect ul {
  display: none;
  position: absolute;
  z-index: 999;
  left: 0;
  top: 1.2rem;
  margin: 0;
  width: 100%;
  background: #fff;
  border: 1px solid #d6d6d6;
}

.cselect li {
  padding: 10px 5%;
  list-style: none;
}

.cselect li:hover {
  background: rgba(41,0.2);
}

.hide {
  display: none;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="rows">
  <div class="row1">
    <div class="cselect options1">
      <input type="text" disabled placeholder="Select n1">
      <ul>
        <li class="option option1" data-hidden="1">Business</li>
        <li class="option option2">Hair</li>
        <li class="option option3" data-hidden="3">Face</li>
      </ul>
    </div>
    <div class="cselect options2 hide" data-hidden="1">
      <input type="text" disabled placeholder="new test">
      <ul>
        <li class="option option1">test</li>
        <li class="option option2">option 2</li>
      </ul>
    </div>
    <div class="cselect options2 hide" data-hidden="3">
      <input type="text" disabled placeholder="face type">
      <ul>
        <li class="option option1">type 1</li>
        <li class="option option2">type 2</li>
      </ul>
    </div>
  </div>
  <div class="row2">

    <div class="cselect options3">
      <input type="text" disabled placeholder="Select n2">
      <ul>
        <li class="option">Something</li>
        <li class="option">Else</li>
      </ul>
    </div>
  </div>
  <div class="clonerow">
    click me
  </div>
</div>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-