解决 border-radius 元素在应用了 transform 的子元素 时overflow:hidden 失效的问题
受大家启迪,于是最近深入研究了一下Css3中的一些属性。之中也是碰到了个不为我知的问题,在这里特此总结并与大家分享。
问题重现:在父元素上应用了 border-radius 的圆角属性、加上 overflow:hidden属性 、并且子元素填充整个父元素。于是看到的效果是:子元素超出父元素圆角的部分被隐藏掉,形成一个圆角头像容器的结构。代码如下:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>test</title>
<style>
html,body{
width: 100%;
height: 100%;
} #father {
width: 200px;
height: 200px;
overflow: hidden;
border-radius: 50%;
background-color: #ccc;
}
#child {
background-color: red;
width: 100%;
height: 100%;
-webkit-transition:all 0.5s ease;
transition:all 0.5s ease;
}
</style> </head>
<body> <div id="father">
<div id="child"></div>
</div> </body>
</html>
效果如下:
想着使用translate3d实现对半圆的动画效果,于是乎问题就显现了。
问题描述:对 #child
应用一个 transform
变化,使用 translate3d
对其进行横向偏移。会发现 #child
溢出了 #father
的圆角范围。 overfow:hidden
失效。
代码如下:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>test</title>
<style>
html,body{
width: 100%;
height: 100%;
} #father {
width: 200px;
height: 200px;
overflow: hidden;
border-radius: 50%;
background-color: #ccc;
}
#child {
background-color: red;
width: 100%;
height: 100%;
-webkit-transition:all 0.5s ease;
transition:all 0.5s ease;
} /*使用 translate3d 让子元素沿x正轴偏移100px*/
#child.add-translate {
-webkit-transform:translate3d(100px,0,0);
transform:translate3d(100px,0,0);
}
</style> </head>
<body> <div id="father">
<div id="child" class="add-translate"></div>
</div> </body>
</html>
使用 translate3d 让子元素沿x正轴偏移100px
显示如下:
解决方案:
1:使用webkit-mask-image 覆盖圆角溢出部分。(文章后面会提供关于webkit-mask-image的相关介绍)
-webkit-mask-image 可以使用图片、Gradient 渐变或者 SVG mask 作为元素的 mask 遮罩。在 WebKit 的兼容性还算可以。
(图片来源于 CSS遮罩 – w3cplus )
回到刚才的问题。在这里使用一个纯黑色的 1px png 图像。应用 mask 遮罩解决该问题。在#father 上应用 add-mask-image类名后,#child触发 transform 动画后就不会出现溢出的问题了。代码如下:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>test</title>
<style>
html,body{
width: 100%;
height: 100%;
} #father {
width: 200px;
height: 200px;
overflow: hidden;
border-radius: 50%;
background-color: #ccc;
}
#child {
background-color: red;
width: 100%;
height: 100%;
-webkit-transition:all 0.5s ease;
transition:all 0.5s ease;
} /*使用 translate3d 让子元素沿x正轴偏移100px*/
#child.add-translate {
-webkit-transform:translate3d(100px,0,0);
transform:translate3d(100px,0,0);
} /*使用 -webkit-mask-image 遮罩*/
#father.add-mask-image{
-webkit-mask-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAIAAACQd1PeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAA5JREFUeNpiYGBgAAgwAAAEAAGbA+oJAAAAAElFTkSuQmCC);
}
</style> </head>
<body> <div id="father" class="add-mask-image">
<div id="child" class="add-translate"></div>
</div> </body>
</html>
使用 -webkit-mask-image 遮罩
效果如下:
该问题在Stackoverflow的讨论:
webkit-overflow-issue-on-border-radius-and-transform
how-to-make-css3-rounded-corners-hide-overflow-in-chrome-opera
有关-webkit-mask-image的简单介绍:
http://ued.ctrip.com/webkitcss/prop/mask-image.html
2:父元素加上 transform 属性。
子元素在使用了 transform 属性后致使它改变了原有的默认维度,而这时的父元素无任何改变,仍为2d维度(css默认都为2d维度)。因此导致了子元素使用translate3d属 性后出现溢出的情况。接下来只要在原有的父元素样式中加上 transform 属性将父元素改变维度即可。(可以使用translate3d 或 rotate 解决)
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>test</title>
<style>
html,body{
width: 100%;
height: 100%;
} #father {
width: 200px;
height: 200px;
overflow: hidden;
border-radius: 50%;
background-color: #ccc;
transform:translate3d(0,0,0);/*父元素使用transform:translate3d 属性*/
-webkit-transform:translate3d(0,0,0);
}
#child {
background-color: red;
width: 100%;
height: 100%;
-webkit-transition:all 0.5s ease;
transition:all 0.5s ease;
} /*使用 translate3d 让子元素沿x正轴偏移100px*/
#child.add-translate {
-webkit-transform:translate3d(100px,0,0);
transform:translate3d(100px,0,0);
}
</style> </head>
<body> <div id="father">
<div id="child" class="add-translate"></div>
</div> </body>
</html>
父元素增加 transform:translate3d 属性
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>test</title>
<style>
html,body{
width: 100%;
height: 100%;
} #father {
width: 200px;
height: 200px;
overflow: hidden;
border-radius: 50%;
background-color: #ccc;
-webkit-transform:rotate(0deg);/*父元素使用transform:rotate 属性*/
transform: rotate(0deg);
}
#child {
background-color: red;
width: 100%;
height: 100%;
-webkit-transition:all 0.5s ease;
transition:all 0.5s ease;
} /*使用 translate3d 让子元素沿x正轴偏移100px*/
#child.add-translate {
-webkit-transform:translate3d(100px,0,0);
transform:translate3d(100px,0,0);
}
</style> </head>
<body> <div id="father">
<div id="child" class="add-translate"></div>
</div> </body>
</html>
父元素增加 transform:rotote 属性
效果:同解决方案一中实现的效果如出一辙,在这里就不贴图了,有兴趣的朋友可以亲自证明一下。
transform的介绍:
三:补充内容(待注意)
1:关于感谢:
a:首先非常感谢大家对 Lying 的启迪。如有需要,留下你们的评论,随时提供服务。
b:感谢前文作者。Lying 在借鉴的原文章上增加了一些自个的见解。有时间咋们见个面呗
2:关于文章内容:
a:没有对浏览器做兼容测试。(搬砖中写的一篇文章)
b:Stackoverflow 上许多友人都说这是 google 的一个bug,因此在这里不能保证解决方案的第二条阐述的正确与否。但这条肯定是可以解决问题的 (chrome中亲测有效)
c:相信还会有其它的解决方案。(简单的看了 Stackoverflow 提供的一些方案,因此在这里没有列出,大家也可以查看文中提供的链接了解了解)
3:关于对Css 3 见解:
a:Css 3 的确是很值得学习的,今后 Lying 也会同大家一起一直保持着学习的积极性和善于分享的心。
解决 border-radius 元素在应用了 transform 的子元素 时overflow:hidden 失效的问题的更多相关文章
- CSS开发技巧(四):解决flex多行布局的行间距异常、子元素高度拉伸问题
在使用flex布局时,若出现换行,有两种较为特殊的现象是值得我们研究的: 子元素高度被拉伸,其实际高度大于它的内容高度. 各行子元素之间的行间距过大,甚至我们根本没有给子元素设置margin. 现在我 ...
- 父元素高度设置为min-height,子元素高度设置为100%,但实际上子元素高度你知道是多少吗?
前言 给父元素一个min-height,子元素设置height:100%. 代码 <!DOCTYPE html> <html> <head> <title&g ...
- border-radius元素overflow:hidden失效问题
父元素使用border-radius和overflow:hidden做成圆形,子元素如果使用了transform属性,则父元素的overflow:hidden会失效. 解决方法: 父元素使用 -wei ...
- 微信小程序 CSS border-radius元素 overflow:hidden失效问题 iPhone ios 苹果兼容问题 伪类元素
同事找我解决一个问题 说安卓圆角没问题 苹果上失效了 我一看 其实就是没做兼容上图给你们看看 有没有看出来 其实就是父级设置圆角属性失效 父元素使用border-radius和overflow:hid ...
- css ie7中overflow:hidden失效问题及解决方法
css兼容ie7: 做页面的时候用负边距居中的时候在IE7下面,父节点中的overflow:hiden失效的问题,查阅了一些资料,总结一下解决方法. 问题原因: 当父元素的直接子元素或者下级子元素的样 ...
- ie6-7 overflow:hidden失效问题的解决方法
即使父元素设置了overflow:hidden.解决这个bug很简单,在父元素中使用position:relative; zoom: 1;触发haslayout 即可解决该BUG.
- 改变父元素的透明度,不影响子元素的透明度—css
1.如果我们给父元素添加opacity:0.4后,子元素的red颜色也变成了0.4的透明度, 例子如下: <!DOCTYPE html> <html> <head> ...
- div高度自适应(父元素未知,所有高度跟随子元素最大的高度)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- CSS子元素居中(父元素宽高已知,子元素未知)
<style> .container{width:400px; height:400px; position:relative;} .center{position:absolute; l ...
随机推荐
- JavaScript 中的 this
JavaScript 语言中的 this 由于其运行期绑定的特性,JavaScript 中的 this 含义要丰富得多,它可以是全局对象.当前对象或者任意对象,这完全取决于函数的调用方式.JavaSc ...
- 在iptables防火墙下开启vsftpd的端口
在开启vsftpd端口后发现用客户端工具能登陆,但无法浏览文件和新建文件.此时看了一下ftp的协议,发现ftp有主动模式和被动模式.在服务端开21端口是让客户端进来,并没有出去的端口,还在服务端开启出 ...
- VC中Source Files, Header Files, Resource Files,External Dependencies的区别
VC中Source Files, Header Files, Resource Files,External Dependencies的区别 区别: Source Files 放源文件(.c..cpp ...
- HDU1724 Ellipse(数值积分)
补一下一些小盲区,譬如simpson这种数值积分的方法虽然一直知道,但是从未实现过,做一道例题存一个模板. #pragma warning(disable:4996) #include<iost ...
- 深入浅出ES6(十二):代理 Proxies
作者 Jason Orendorff github主页 https://github.com/jorendorff 请看这样一段代码: var obj = new Proxy({}, { get: ...
- ELk 几篇好的文章
https://nxlog.co/docs/elasticsearch-kibana/using-nxlog-with-elasticsearch-and-kibana.html http://www ...
- Windbg 常用命令整理
kd> !idt -a 查看idt kd> dt _ktrap_frame 异常帧 kd> ba e1 Address 下硬件执行断点kd> ba w4 Addr ...
- android自动化环境搭建
android自动化环境安装指南 1.appium相关安装(eclipse下)见http://www.cnblogs.com/wangcp-2014/p/5717589.html参考selenium的 ...
- VS2013试用期结束后如何激活
在激活框中输入密钥:BWG7X-J98B3-W34RT-33B3R-JVYW9
- Junit单元测试学习笔记二
我们使用Eclipse自动生成了一个测试框架,在这篇文章中,我们来仔细分析一下这个测试框架中的每一个细节,知其然更要知其所以然,才能更加熟练地应用JUnit4. 一. 包含必要地Package ...