首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何通过折叠标题中的输入元素停止`click`冒泡,以避免激活折叠元素

如何通过折叠标题中的输入元素停止`click`冒泡,以避免激活折叠元素
EN

Stack Overflow用户
提问于 2015-06-02 03:13:09
回答 1查看 665关注 0票数 0

我得到了一个在accordion标题中带有<input>的jQuery accordion。手风琴是“可折叠的”,但我不希望在<input>中单击时展开(或折叠)该项目。

如何停止通过<input>元素冒泡的click事件,以避免激活accordion元素?

有没有什么聪明的方法可以将event.stopPropagation(); (或类似的东西)应用到accordions beforeActivate-callback?或者这可以直接在<input>的数据绑定上完成?

在我的bindingHandler上:

代码语言:javascript
复制
       $(element).accordion({
            header: ".accordion-header",
            collapsible: true,
            navigation: true,
            heightStyle: "content",
            active: false,

            beforeActivate: function (event, ui) {
                active = $(this).accordion("option", "active");
            },
            activate: function (event, ui) {
                event.stopPropagation(); // This obviously has no effect
            }
        })
EN

回答 1

Stack Overflow用户

发布于 2015-06-02 03:16:04

你这样做是对的,.stopPropagation()是正确的,你只是没有把它放在正确的位置,它会进入输入的点击处理程序。

例如。

代码语言:javascript
复制
$(document).on('click', '.my-input', function(e){
     e.preventDefault();   // throw this in for good measures too
     e.stopPropigation();

    //  your code to handle click here
});

HTML

代码语言:javascript
复制
<input data-bind="click: clickHandler" />

淘汰赛:

代码语言:javascript
复制
clickHandler = function(e){
        e.preventDefault();   // throw this in for good measures too
        e.stopPropigation();
};
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30581391

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档