Html 点透镂空遮罩,CSS实现镂空遮罩

前一阵子面试被问题到这个问题,突然懵逼了,脑子一片空白,以前知道这种效果,比如什么值得买的改版引导页面:

cce983eef45f9eb36b2ad80d5d1af632.png

当时再紧张也应该打出一种实现方法,就是什么值得买这种使用图片实现

4ef858dd45663b6509bb02a652efa4cd.png

它首先加了一个半透明的黑色蒙层(background-color: rgba(0,0,0,.8))然后添加提前制作好的图片作为子元素,然后通过决定定位,让图片与被遮盖的部分的定位相同,制造出一种假的镂空的效果

虽然这种方式处理定位有一些麻烦,并且不适合页面有滚动的情况,滚动的时候可能出现错位。

但是当时怎么也应该答出这种方式,但是确实一面试就紧张,脑子不转了,就想着添加一个伪元素,但是不知道怎么穿透。

回来查了一些资料,找到了几种实现的方法

首先准备好要被遮罩的DOM结构:

这是要露出来的字

这是要露出来的字

这是要露出来的字

复制代码

以及样式:

.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;

}

复制代码

此时的效果:

ed0d208e465406060bb2c744da25844c.png

要实现的效果:

69570f50e46de35cc77c727d4e73057b.png

透明边框

中间的镂空部分为实际的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直接画出这样的一个形状,这里就需要介绍一下非零环绕规则

29ceba36ef7b4f6bcd6ee535f175b593.png

所以在画外围的半透明矩形时顺时针,那么里面镂空的矩形就需要逆时针:

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基本上是不了解的,直接复制修改了一段代码

复制代码

也不是很复杂。

总结

如果页面布局尺寸都是固定的,可以使用CSS的三种方法实现

如果实现效果比较复杂,可以使用Canvas或者SVG实现

如果要偷懒,可以让UI出一张图片实现

参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值