当前位置: 首页 > 知识库问答 >
问题:

单击用.append()[duplicate]导入的子元素时未检测到单击

魏康安
2023-03-14

我制作了一个“组件”系统,它将HTML代码附加到包含某些类的某些元素,例如以下元素:

   <!-- eBtn -->
   <div class="eBtn pageChanger" text="SPEED TEST" page="demo" style="margin-bottom: 10px;"></div>

导入一个写有“速度测试”的按钮。导入的buton具有以下代码模板:

 <!-- eBtn -->
 <div class="frow center">

    <div class="eBtn-left frow center">

        <div class="eBtn-line-c2 fcol center">
            <div class="eBtn-line2"></div> 
         </div>

        <div class="eBtn-line-c1 fcol center">
           <div class="eBtn-line1 l1l"></div> 
        </div>

    </div>

    <div class="eBtn-frame">

        <div class="eBtn-bg">
            <span id="eBtn" class="eBtn-text uB">text</span>
        </div>

    </div>

    <div class="eBtn-right frow center">
        
        <div class="eBtn-line-c1 fcol center">
            <div class="eBtn-line1 l1r"></div> 
        </div>

        <div class="eBtn-line-c2 fcol center">
            <div class="eBtn-line2"></div> 
        </div>

    </div>

</div>

使用这个模板,我可以轻松地导入组件,但我遇到了一个问题,我不知道如何解决,我前面显示的第一个具有ebtn类的元素也具有PageChanger类和一个page属性,我的导航脚本使用以下函数来更改页面:

    $(".pageChanger").click(function() { // When user click on a pagechanger elt
            clearTimeout(eContainerInstance); // Clear the eContainer instance to avoid weird bahavior
            clearTimeout(navLoadInstance); // Clear navLoad instance
            var newPage = $(this).attr("page"); // get clicked elt destination
            console.log(newPage)
            changePage(newPage); // Change page to the desired page
            $(".navbar").addClass("toggled"); // add toggled to navbar to be sure it is not affected by ScrollFx until user scrolls
    });

它适用于除了我的EBTN之外的任何其他元素,我确实使用ebtn容器来用CSS动画它的内容,这样当单击它时它应该可以工作(我甚至在它上面添加了pointer-events:all)但函数甚至没有被调用。

我不知道在单击PageChanger的子元素时如何触发该函数。

共有1个答案

亢嘉茂
2023-03-14

在执行jQuery时,可能还没有加载动态HTML内容。

您可以尝试在文档上添加事件侦听器,如下所示,以便使它在任何动态添加的HTML内容上工作:

$(document).on('click', '.pageChanger', function(){ ... });
 类似资料:
  • 当单击的elemenet是父元素的最后一个子元素时,我要显示报警。我的HTML结构: 在本例中,我希望在单击该元素(父行的最后一个元素)时显示报警: 我知道我可以使用这样的somethink获得最后一个元素(但我不能在我的例子中使用这个): 我想试着做这样的事,但每次都是假的

  • 如果孩子在焦点中(已被点击),我怎么能失去父母的悬停状态?我有一个菜单箭头(用OPEN代替了它,以减少代码),它在悬停状态下打开我的菜单和菜单项,当我单击它们时,菜单项就会聚焦。在菜单项点击后,我希望能够失去对我父母的关注,这样菜单就会消失。 如果可能的话,我会尽量避免使用javascript,这是我最好的尝试... 这是我的html null null 编辑 我在一个单页应用程序上使用Angul

  • 这是我的问题。 我有一个像这样的简单表格(示例): null null 并且我正在尝试列的名称,同时单击元素。 我想这可能是一个简单的解决办法但我找不到。 提前致谢

  • 我正在学习使用Java和Eclipse IDE的Selenium测试自动化。我正在尝试开发自己的XPAHT,但我在浏览器上安装了Chropath来帮助解决我自己无法解决的问题。在尝试与play按钮交互时,我遇到了以下问题几次。测试的目标是导航到网站的播客页面,选择一个播客,点击播放按钮。我尝试开发自己的xpath,但没有找到任何工作的xpath。我检查了Chropath插件,得到了这样的消息: 它

  • 问题内容: 我正在尝试没有Jquery的情况。我想在单击触发器时显示div。到目前为止,我已经隐藏了这个元素。 HTML .. 单击链接时如何创建显示div的函数?我想避免在链接本身中使用类似的功能。 问题答案: