jQuery简单的点击容器内元素与容器外判断

广告位招租
扫码页面底部二维码联系

点击容器内的元素会响应事件(显示某个元素【未经授权禁止转载】【版权所有,侵权必究】),点击容器外则响应另外一个事件(隐藏某【未经授权禁止转载】【版权所有,侵权必究】个元素),那么如何断定点击的某个元素为容未经授权,禁止复制转载。【关注微信公众号:wwwtangshuangnet】器外元素呢?这个问题看上去好简单,实际上【版权所有,侵权必究】【转载请注明来源】很难。

转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】

例如我们有下面的一串html代码:

【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。
<div id="root">
  <div id="parent">
    <div id="child"></div>
  </div>
</div>

上面的代码中,我们点击#child则显示转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。某元素,点击非#child则隐藏该元素,【原创不易,请尊重版权】未经授权,禁止复制转载。可是当我们如何绑定,都会遇到点击#chi【未经授权禁止转载】【本文首发于唐霜的博客】ld,会激活#root或#parent的【版权所有,侵权必究】【转载请注明来源】绑定事件,而且我们常常通过直接绑定doc【版权所有】唐霜 www.tangshuang.net本文作者:唐霜,转载请注明出处。ument的点击事件来实现该功能,实际上【关注微信公众号:wwwtangshuangnet】本文版权归作者所有,未经授权不得转载。点击#child的同时也是点击docum【原创内容,转载请注明出处】【作者:唐霜】ent,最后的结果是无论你点击#chil【转载请注明来源】【转载请注明来源】d与否,都隐藏该元素,从肉眼感觉就像什么【本文首发于唐霜的博客】【关注微信公众号:wwwtangshuangnet】也没有发生一样。那么究竟应该如何避免点击【原创内容,转载请注明出处】【关注微信公众号:wwwtangshuangnet】#child时容器外事件被触发呢?如下代著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。码即可解决。

【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。【原创不易,请尊重版权】
var _itemClick = false;

$(document).on('click', function() {
  if(!_itemClick) $('#att-info').html('');
});

$('#list .item,#att-info').on('click',function() {
  _itemClick = true;
  setTimeout(function() {
    _itemClick = false;
  },100);
});

2015-08-23 5054

为价值买单,打赏一杯咖啡

本文价值50.54RMB