- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
抱歉标题可能不清楚,但我不知道如何准确描述我面临的问题。我创建了一个 jsFiddle希望澄清问题。
我有以下布局,其中所有 4 个 div 都有 opacity: 1
和 visibility: visible
和 div a 和 b 都有 position:absolute
和 top: 0
和 left: 0
。
<div class="a">
<div class="child-a"></div>
</div>
<div class="b">
<div class="child-b"></div>
</div>
如果您查看示例,您可以将 div b 更改为:opacity: 0
和 visibility: hidden
(这发生在转换).现在你只看到 div a 和它的 child child-a。你可以点击 div a 但你不能点击 child-a。如果您尝试这样做,您实际上会点击 child-b。
尽管 child-b 的父级不再被鼠标事件触发并且似乎被隐藏了,但它仍然会监听/被它们触发。我希望 child 也像其 parent 一样“真正”隐藏起来。
我如何确保点击您看到 child-a 的区域实际上也应用于child-a?我确实希望能够在显示和隐藏 div 之间使用不透明度转换,因此使用 display:none
是您无法转换的(据我了解)。
我确实在示例中添加了 display:none
切换,因为该切换确实按照我期望的方式运行(只有这样你才能再转换)。
最佳答案
你可以玩一下pointer-events
:
.fade-in {
pointer-events: none;
}
.fade-in.show-me {
pointer-events: auto;
}
.fade-in .fade-in {
pointer-events: none;
}
.show-me .show-me {
pointer-events: auto;
}
这是一个演示:
var a = document.getElementsByClassName("a")[0];
var b = document.getElementsByClassName("b")[0];
var c = document.getElementsByClassName("c")[0];
var d = document.getElementsByClassName("d")[0];
var e = document.getElementsByClassName("e")[0];
var childA = document.getElementsByClassName("child-a")[0];
var childB = document.getElementsByClassName("child-b")[0];
c.onclick = function () {
if (b.classList.contains("show-me")) {
b.classList.remove("show-me");
} else {
b.classList.add("show-me");
}
};
d.onclick = function () {
if (b.classList.contains("hide")) {
b.classList.remove("hide");
} else {
b.classList.add("hide");
}
};
a.onclick = function () { console.log("a");e.innerHTML = "a<br>"+e.innerHTML; };
b.onclick = function () { console.log("b");e.innerHTML = "b<br>"+e.innerHTML; };
childA.onclick = function (ev) {ev.stopPropagation(); console.log("child-a");e.innerHTML = "child-a<br>"+e.innerHTML; };
childB.onclick = function (ev) {ev.stopPropagation(); console.log("child-b");e.innerHTML = "child-b<br>"+e.innerHTML; };
.a,
.b {
position: absolute;
top: 10px;
left: 10px;
cursor: pointer;
}
.a:hover,.b:hover {
box-shadow: 0 0 2px #000;
}
.a {
background-color: #fee;
}
.b {
background-color: #eef;
}
.child-a,.child-b {
float: left;
width: 80px;
height: 80px;
margin: 25px;
box-shadow: 0 0 2px #000;
cursor: pointer;
line-height: 100px;
text-align: center;
}
.child-a:hover,.child-b:hover {
box-shadow: 0 0 4px #000;
}
.fade-in {
opacity: 0;
visibility: hidden;
transition-delay: 0s;
transition-duration: 200ms;
transition-property: opacity, visibility;
transition-timing-function: ease;
pointer-events: none;
}
.fade-in.show-me {
opacity: 1;
visibility: visible;
pointer-events: auto;
}
.fade-in .fade-in {
pointer-events: none;
}
.show-me .show-me {
pointer-events: auto;
}
.c, .d {
width: 240px;
height: 40px;
margin-top: 30px;
cursor: pointer;
background-color: #fff;
margin-left: 160px;
box-shadow: 0 0 2px #000;
line-height: 40px;
text-align: center;
border-radius: 3px;
}
.c:hover, .d:hover {
box-shadow: 0 0 4px #000;
}
.hide {
display: none;
}
.e {
clear: both;
}
<div class="a fade-in show-me">
<div class="child-a fade-in show-me">a-child</div>
</div>
<div class="b fade-in show-me">
<div class="child-b fade-in show-me">b-child</div>
</div>
<div class="c">Toggle b opacity and visibility</div>
<div class="d">Toggle b display</div>
<div class="e"></div>
关于html - 在使用不透明度和可见性属性时,如何让 child 遵循与 parent 相同的行为?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40392023/
如果我需要选择第 10 个父级,是否有更简洁的方法,然后重复 .parent() 10 次? $('#element_id').parent().parent().parent().parent().
从 angularJS 指南中的“如何创建通信指令”开始,https://docs.angularjs.org/guide/directive , 我正在尝试使用该布局来制作可导航的表单。 问题在于指
我有一个 jQuery 函数,需要获取元素父元素的位置。 它看起来像: function show(e) { //debugger; var nextTab
我正在尝试修复这个难看的代码。 RadGrid gv = (RadGrid) (((Control) e.CommandSource).Parent.Parent.Parent.Parent.Pare
我有一个 A 标签,可以触发它的曾曾曾祖 parent 的动画。以下所有方法都可以,但哪一个最有效,为什么? $(this).parent().parent().parent().parent().p
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 9 年前。 Improv
我在尝试定位绝对定位的 div 时遇到了一些问题。我猜它的工作方式应该是这样,但是我希望它与父对象的父对象而不是父对象一起使用,因为我有一个下拉列表,当我希望它像第一个一样保持在顶部时,它会跟随父对象
我正在做一些非常基本的 jQuery 东西,真正开始,我经常通过做类似的事情来向上导航 dom $(this).parent().parent().addClass('hello'); 我只是想知道是
此 HTML 结构有一个 div#page,其中当前页面内容将通过 Ajax 加载。内容始终由 section 标记组成,这些标记可以具有动态高度(相对于浏览器的百分比)或静态高度(以像素为单位)。
在 javascript 中是否有一种简单的方法来定位父对象的父对象? 我使用 this.parentNode 作为函数的元素来选择父节点,我尝试了 this.parent.parentNode 和
当遍历 pager.Pages 对象的 foreach 循环时,$data 是 self(正如预期的那样)。但是,$parent 应该是寻呼机对象,但它返回的是 WaterQualityResultV
在架构中,我想根据父级的 sibling 调整架构。 例如:如果 toggleMonday 为真,那么 weekdays -> monday 应该有一个特定的验证模式。 现在下面的例子有效。但是,它非
我想要完成的是,当用户将焦点放在文本框上时,其中的字段集将添加一个类“active_fieldset”,以便提供用户在表单中的位置的良好视觉提示。使用以下 javascript,它确实会影响父字段集,
我创建了这个函数来保存我的taches sauverTache(tache:Tache){ this.editionEnCours = true; tache.estReelle =
所以..这是我的问题..我有以下代码(示例): var GameObject = function (posX, posY, width, height) { this.posX = posX;
所以,我是 jQuery 的新手,我正在尝试更改关于函数触发器的 2 个级别的 div: 这是我的第一次尝试:我尝试找到最接近的“.node”,它是所有其他 div 的父级并编辑子 div。 fun
我想了解为什么使用 ng-repeat在repeat 的item 上有某个controller,那个item 的parent 和那个item 的祖父是同一个controller。我期待祖父成为父 Co
我想从我的组件 Controller 之一将 jsonModel 设置为我的 SAPUI5 组件。在组件内,我使用应用程序或 splitapp。 我想避免通过 ID 获取元素。从组件内的某个位置获取层
我不确定如何在标题上准确地表达出来,因为问题在我的场景中太具体了,但无论如何基本上我有两个类似于下面的外部类: class Config { public level: number = 1;
在我正在编写的这个脚本中,我发现自己连续使用 .parent() 最多七次来获取元素。虽然这有效,但似乎可以/应该有一种更简单的方法来完成我不知道的这个/功能。除了更多元素上更具体的类/ID 之外,还
我是一名优秀的程序员,十分优秀!