前一阵子面试被问题到这个问题,突然懵逼了,脑子一片空白,以前知道这种效果,比如什么值得买的改版引导页面:
当时再紧张也应该打出一种实现方法,就是什么值得买这种使用图片实现
它首先加了一个半透明的黑色蒙层( background-color: rgba(0,0,0,.8)
)然后添加提前制作好的图片作为子元素,然后通过决定定位,让图片与被遮盖的部分的定位相同,制造出一种假的镂空的效果
虽然这种方式处理定位有一些麻烦,并且不适合页面有滚动的情况,滚动的时候可能出现错位。
但是当时怎么也应该答出这种方式,但是确实一面试就紧张,脑子不转了,就想着添加一个伪元素,但是不知道怎么穿透。
回来查了一些资料,找到了几种实现的方法
首先准备好要被遮罩的DOM结构:
<div class="outer"> <div class="content"> <p>这是要露出来的字</p> <p>这是要露出来的字</p> <p>这是要露出来的字</p> </div> <div class="inner"></div> </div>
以及样式:
.outer { position: relative; margin: 20px 0; height: 500px; background: darksalmon; overflow: hidden; } .content { width: 200px; height: 80px; color: #FFF; line-height: 1.5; background: #5b8b7b; margin: 100px 0 0 100px; }
此时的效果:
要实现的效果:
透明边框
中间的镂空部分为实际的 width 和 height ,为完全透明的背景,而四周半透明的遮罩使用 rgba 的 border 来实现
.inner { position: absolute; left: 0; top: 0; box-sizing: content-box; width: 200px; height: 80px; border-color: rgba(0, 0, 0, 0.5); border-style: solid; border-width: 100px 1500px 1500px 100px; background: transparent; }
透明轮廓
使用边框的地方,大多数时候都可以使用轮廓 outline 来替代,实际上没有什么不同,只是要注意, outline 是不占据文档流空间的,所以定位方式与使用 border 时不同
.inner2 { position: absolute; left: 100px; top: 100px; box-sizing: content-box; width: 200px; height: 80px; outline: rgba(0, 0, 0, 0.5) 1500px solid; background: transparent; }
透明阴影
还可以使用透明阴影实现,主要利用了阴影的第四个扩展半径这个参数
.inner3 { position: absolute; left: 100px; top: 100px; box-sizing: content-box; width: 200px; height: 80px; box-shadow: rgba(0, 0, 0, 0.5) 0 0 0 1500px; background: transparent; }
使用Canvas实现
可以使用强大的Canvas实现,当然使用Cavnas就需要使用脚本来编写了,虽然有些复杂,但是使用灵活,能够适应各种不同的要求,比如同时镂空多个等等。
使用Canvas也有两种方式来实现,第一种方式是使用 clearRect 方法,比较简单:
const canvas = document.querySelector('#canvas'); const ctx = canvas.getContext('2d'); ctx.fillStyle = 'rgba(0, 0, 0, 0.5)'; ctx.fillRect(0, 0, 1500, 1500); ctx.clearRect(100, 100, 200, 80);
另一种方式是自己通过 path 直接画出这样的一个形状,这里就需要介绍一下 非零环绕规则
所以在画外围的半透明矩形时顺时针,那么里面镂空的矩形就需要逆时针:
const canvas = document.querySelector('#canvas2'); const ctx = canvas.getContext('2d'); // 外围 ctx.moveTo(0, 0); ctx.lineTo(1500, 0); ctx.lineTo(1500, 1500); ctx.lineTo(0, 1500); ctx.closePath(); // 内层 ctx.moveTo(300, 100); ctx.lineTo(100, 100); ctx.lineTo(100, 180); ctx.lineTo(300, 180); ctx.closePath(); ctx.fillStyle = 'rgba(0, 0, 0, 0.5)'; ctx.fill();
使用SVG实现
我对SVG基本上是不了解的,直接复制修改了一段代码
<svg class="svg" width="1500" height="500"> <defs> <mask id="myMask"> <rect x="0" y="0" width="100%" height="100%" style="stroke:none; fill: #ccc"></rect> <rect width="200" height="80" x="100" y="100" style="fill: #000"></rect> </mask> </defs> <rect x="0" y="0" width="100%" height="100%" style="stroke: none; fill: rgba(0, 0, 0, 0.6); mask: url(#myMask)"></rect> </svg>
也不是很复杂。
总结
- 如果页面布局尺寸都是固定的,可以使用CSS的三种方法实现
- 如果实现效果比较复杂,可以使用Canvas或者SVG实现
- 如果要偷懒,可以让UI出一张图片实现
以上所述是小编给大家介绍的CSS实现镂空遮罩效果,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。