为什么 B 站的弹幕可以不挡人物
大厂技术 高级前端 Node进阶
点击上方 程序员成长指北,关注公众号
回复1,加入高级Node交流群
作者:钱得乐
https://juejin.cn/post/7141012605535010823
![](https://filescdn.proginn.com/64025bd125edd839f2f0fa80f1eef1c6/243798cc14ebd4ee069a513fc841afda.webp)
高端的效果,往往只需要采用最朴素的实现方式,忙碌了两个小时,陈师傅打开了F12,豁然开朗。一张图片+一个属性,直接搞定。
![](https://filescdn.proginn.com/051ff4ee1de1d38df76b197454b5ac19/af4e46fd8c2e6f5ae85c3914476e2116.webp)
![](https://filescdn.proginn.com/2aac72401f0b426ba2de5f832e64e941/9d29ebc88a187d6f15a5daefa2c78538.webp)
为了印证我的想法,我决定自己写一个demo
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
.video {
width: 668px;
height: 376px;
position: relative;
-webkit-mask-image: url("mask.svg");
-webkit-mask-size: 668px 376px;
}
.bullet {
position: absolute;
font-size: 20px;
}
</style>
</head>
<body>
<div class="video">
<div class="bullet" style="left: 100px; top: 0;">元芳,你怎么看</div>
<div class="bullet" style="left: 200px; top: 20px;">你难道就是传说中的奶灵</div>
<div class="bullet" style="left: 300px; top: 40px;">你好,我是胖灵</div>
<div class="bullet" style="left: 400px; top: 60px;">这是第一集,还没有舔灵</div>
</div>
</body>
</html>
效果是这样的
![](https://filescdn.proginn.com/aadc137c628cf7e5dadc2a00c96c277a/50d1be164f6a57957a52a5973933c8f6.webp)
加一个红背景,看的清楚一些
![](https://filescdn.proginn.com/5d79c515616a329b48ec56bcd9cb716d/ea857480a3d8cc3969cb7c8f070f4152.webp)
至此我们就实现了B站同款的不遮挡人物的弹幕。至于这张图片是怎么来的,肯定是AI识别出来然后生成的,一张图片也就一两K,一次加载很多张也不会造成很大的负担。
最后来看看这个神奇的css属性吧
developer.mozilla.org/zh-CN/docs/…[1]
Experimental: 这是一个实验中的功能
所以在开发需求的时候可以把它当成一个亮点使用,但是不能强依赖于这个属性做需求。
它还有一系列的属性,有兴趣的话可以挨个试一下。
![](https://filescdn.proginn.com/10f1a9ee936813255ae44ca06c3b5a28/afa8789aa3f4d0e43192f682ac7893a4.webp)
参考资料
developer.mozilla.org/zh-CN/docs/…: https://developer.mozilla.org/zh-CN/docs/Web/CSS/mask-image
我组建了一个氛围特别好的 Node.js 社群,里面有很多 Node.js小伙伴,如果你对Node.js学习感兴趣的话(后续有计划也可以),我们可以一起进行Node.js相关的交流、学习、共建。下方加 考拉 好友回复「Node」即可。
“分享、点赞、在看” 支持一波👍
评论