内容简介:byzhangxinxu from本文可全文转载,个人网站无需授权,只要保留原作者、出处以及文中链接即可,任何网站均可摘要聚合,商用请联系授权。
byzhangxinxu from https://www.zhangxinxu.com/wordpress/?p=8305
本文可全文转载,个人网站无需授权,只要保留原作者、出处以及文中链接即可,任何网站均可摘要聚合,商用请联系授权。
一、先快速了解::backdrop伪元素
backdrop这个单词是背景幕布,就是戏曲表演后面的一块布。
::backdrop
伪元素就是控制需要视觉聚焦的元素后面的背景元素样式的。
在web中哪些元素需要视觉聚焦呢?一个是HTML5 <video>
视频元素,还有就是HTMl5.2 <dialog>
元素,以及处于全屏状态下的普通元素。
下面分别看下 ::backdrop
伪元素在上述这些HTML元素和场景中的表现吧。
二、video元素中的::backdrop
video元素中的::backdrop伪元素可以控制全屏时候视频后面层的样式,默认是纯黑色。我们可以通过设置background相关属性,把全屏播放的视频的幕布背景改成设计师眼中的透明色。
代码如下:
/* 给全屏时候视频背景加个透明 */ video::backdrop { background-color: #fff; background-image: linear-gradient(45deg, #eee 25%, transparent 25%, transparent 75%, #eee 75%, #eee), linear-gradient(45deg, #eee 25%, transparent 25%, transparent 75%, #eee 75%, #eee); background-size: 16px 16px; background-position: 0 0, 8px 8px; }
结果如下截图:
眼见为实,您可以狠狠地点击这里: ::backdrop伪元素控制video的背景demo
//zxx: 需要注意的是,原视频比例16:9,若你的显示器也是16:9,则不会显示幕布背景,此时,可以F12打开开发者 工具 控制台再全屏。
如果想要视频的全屏背景真·用户视觉不可见,下面3种声明都是可以的。
video::backdrop { opacity: 0; }
video::backdrop { visibility: hidden; }
video::backdrop { display: none; }
三、dialog元素中的::backdrop
当我们使用dialog元素内置的 showModal()
显示带背景色的弹框时候,默认色黑色半透明,在我现在使用的Chrome浏览器下是 rgba(0, 0, 0, 0.1);
。
我们可以借助::backdrop伪元素改变弹框的幕布背景样式,例如,变成圈子里人都认为没毛病的透明色:
/* 给弹框背景加个透明 */ dialog::backdrop { background-color: #fff; background-image: linear-gradient(45deg, #eee 25%, transparent 25%, transparent 75%, #eee 75%, #eee), linear-gradient(45deg, #eee 25%, transparent 25%, transparent 75%, #eee 75%, #eee); background-size: 16px 16px; background-position: 0 0, 8px 8px; }
结果弹框出现后的效果如下截图:
眼见为实,您可以狠狠地点击这里: CSS ::backdrop改变dialog元素背景demo
除了控制背景,我们还可以控制尺寸,加阴影等,例如再添加如下CSS:
dialog::backdrop { width: 50%; box-shadow: 0 0 100px 30px; }
效果如下截图:
这里,就可以顺其自然引出关于 ::backdrop
伪元素一个非常重要特性:
::backdrop伪元素既不继承也不继承任何其他元素。任何CSS都可以应用,没有限制。
四、fullscreen API与::backdrop
关于网页内容全屏,很早之前有介绍过,可以参考之前的“ HTML5全屏API在FireFox/Chrome中的显示差异 ”这篇文章。
当借助HTML5 fullscreen API让网页中的某个普通元素全屏的时候,::backdrop伪元素也是可以控制背后的背景的。
例如,我们让一个 <img>
元素全屏,则可以使用下面的CSS让全屏后的图片backdrop背景变成“透明”:
/* 图片全屏后背景透明 */ img::backdrop { background-color: #fff; background-image: linear-gradient(45deg, #eee 25%, transparent 25%, transparent 75%, #eee 75%, #eee), linear-gradient(45deg, #eee 25%, transparent 25%, transparent 75%, #eee 75%, #eee); background-size: 16px 16px; background-position: 0 0, 8px 8px; }
结果如下GIF图所示:
如果心痒痒,想要亲自体验一番,可以狠狠地点击这里: CSS ::backdrop控制全屏img元素背景demo
::backdrop
对背景的控制要比 :-moz-full-screen{}
或 :-webkit-full-screen{}
等伪类要更强。
五、结语
今天微博3大事:坑了我京东股票的强子哥不被起诉;杨幂刘恺威合作生意合同到期;国务院签署完全看不懂的个税新方法。
今天下午去电影院看了《海王》,虽然故事情节简单,事后经不住推荐,但看的时候很high很燃。想想我们厂那些IP故事,故事都很棒的,但是拍出来的有几部片子,实在是……怎么说呢,用同事的话讲就是想趁着吃饭的时间看几集支持下,结果硬是看不下去。先不说特效技术差了10多年,单单就这镜头运用,声音渲染,实在差太多了。
不过嘛,刚开始,不成熟是正常的,希望可以借助资本的力量,让我们国家的影视行业更上一个台阶。小白套路故事也能拍出震撼的效果。
不多扯了,最后说下 ::backdrop
伪元素兼容性吧,和 <dialog>
是一致的,目前仅Chrome浏览器完全支持,Firefox实验支持。
就这样吧,感谢阅读!
本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。
本文地址: https://www.zhangxinxu.com/wordpress/?p=8305
(本篇完)
以上所述就是小编给大家介绍的《CSS ::backdrop伪元素是干嘛用的?》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- CSS 基础:块级元素、行内元素、替换元素、非替换元素
- CSS 技巧篇(六):display设置元素为行内元素时,元素之间存在间隙问题
- 探究行内元素和块级元素
- 重学前端:块级元素与内联元素
- 使CSS伪元素:在与主元素相同的高度之前
- 求非负元素数组所有元素能组合的最大字符串
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。