Framework7 stopPropagation解决方案
Framework7 stopPropagation solution
http://jsfiddle.net/p168uLv2/3/
在这里你可以看到我的jsFiddle伴随着我的问题。我在点击处理程序中有一个按钮,当我按下按钮时,点击也会在按钮所在的div上注册。使用jQuery,您可以停止Propagaton,这样就不会发生这种情况,但在framework7上它不起作用。
<div data-link="level1" class="limodeknop">
<div class="overlay"></div>
<div class="modeknop">
<div class="titel">
<lrmodenaam>Level 1</lrmodenaam>
<lrsubmode>Tutorial</lrsubmode>
</div>
<div class="knoppenbalk displaynone">
<div data-link="solo" class="solo btn">Solo</div>
</div>
</div>
</div>
和Javascript:
var $$ = Dom7;
$$(document).on('click',"[data-link=level1]", function(){
console.log("li clicked");
$$(this).find(".knoppenbalk").toggleClass("displaynone");
});
$$(document).on('click',"[data-link=solo]", function(e){
console.log("solo BUTTON clicked");
e.stopPropagation();
});
问题似乎出在Framework7对事件绑定的实现上。当"click"事件到达根文档的节点时,两个回调都会触发。因此,此步骤中的"stopPropagation"是无用的。
您可以使用"stopImmediatePropagation",但在这种情况下,您必须按正确的顺序排列单击处理程序。请注意,"stopImmediatePropagation"将阻止所有其他处理程序绑定到元素,因此不要将"document"用作目标。
也可以在气泡步骤上使用"stopPropagation"来达到同样的效果。
var $$ = Dom7;
$$('.limodeknop')
.on('click', "[data-link=solo]", function (e) {
console.log("solo BUTTON clicked");
e.stopImmediatePropagation();
});
$$('.limodeknop')
.on('click', "[data-link=level1]", function () {
console.log("li clicked");
$$(this)
.find(".knoppenbalk")
.toggleClass("displaynone");
});
我的CodePen示例。
相关文章:
- 可以转换显示属性吗?如果没有,什么'这是最好的解决方案
- iPad虚拟键盘-哪一个-javasctript解决方案
- AJAX HTTP基本身份验证解决方案
- 在chrome web商店中打开时,是否有允许执行内容/后台脚本的解决方案
- Chart.js-添加渐变而不是纯色-实现解决方案
- learnyounode杂耍异步解决方案不工作
- 了解因子分解解决方案
- 提交表单后的最佳解决方案
- 计时器在使用 jQuery 一分钟后没有触发,或者每 1 分钟后给出一些其他解决方案来触发功能
- chrome中的意外全局变量有解决方案吗
- 更好的解决方案HTML元素幻灯片从右侧CSS转换
- 使用SeleniumWebdriver将文本复制到文件时出现编译错误的解决方案
- 如何让我的网站上的WEBP图像加载在morzilla firefox中有一个可能的解决方案吗?如果是,那么如何
- JS驱动的常见问题页面的推荐DB解决方案
- 这里有一个更优雅的/DRY/可维护的JS解决方案
- 什么是农民最实用的解决方案;印刷动物”;
- 根据某些条件验证用户输入,而不是将输入输入到数组中,需要最基本的解决方案
- 将数据加载到地图上的更好解决方案
- 我根据解决方案按类对
- 元素进行分组,但需要帮助了解它的工作原理
- 当我想发布一个变量但有 1 个 js 时,ajax post 的解决方案是什么