CSS & JS Effect – Image Overlay
介绍
一张背景图, 一行写字, 一层黑影 (Image Overlay), 如果没有做黑影, 字的颜色容易和图片撞, contrast 就会很烂.

HTML 结构
<div class="container">
<h1>Hello World</h1>
</div>
很简单, 因为图片用 background-image 完成, 黑影用 ::after content: '' 完成. 所以不需要什么 element.
CSS style
.container {
height: 400px; /* 给个高度 */
/* 插入背景图片 */
background-image: url("./images/tifa2.PNG");
background-size: cover;
background-position: center;
/* 给 h1 一些 style */
h1 {
color: white;
font-size: 4rem;
}
/* 让 h1 居中 */
display: flex;
justify-content: center;
align-items: center;
}
效果

CSS style for image overlay
.container {
position: relative; /* 让 overlay 定位 */
z-index: 0; /* 阻止 overlay 的 z-index -1 去到更高层 */
&::after {
/* 黑色空 div, 填满整个 container */
content: "";
width: 100%;
height: 100%;
background-color: rgba($color: black, $alpha: 0.5);
/* 和 container 重叠 */
position: absolute;
top: 0;
left: 0;
z-index: -1; /* 必须小于 container 内其它元素 */
}
}
通过 ::after 做出 overlay 然后定位让它和 container 重贴, 再加上 z-index 确保 container 原先内容没有被挡住.
Tips: top, left, width, height
top: 0;
left: 0;
width: 100%;
height: 100%;
可以写成 top, left, bottom, right (但要小心坑)
top: 0;
left: 0;
bottom: 0;
right: 0;
也相等于 shorthand inset: 0
inset: 0;
冷知识: 但这招对 iframe 无效哦, iframe 只接受 width, height 100%, left rigth:0 无法等价于 width 100% 效果, 原理没去查.
效果

当遇上 rounded corners
如果 container 有圆角.
border-radius: 2rem;
效果

overlay 超出圆角了. 解决方法是在 container 加上 overflow: hidden
Final CSS Style
.container {
height: 400px; /* 给个高度 */
/* 插入背景图片 */
background-image: url("./images/tifa2.PNG");
background-size: cover;
background-position: center;
/* 给 h1 一些 style */
h1 {
color: white;
font-size: 4rem;
}
/* 让 h1 居中 */
display: flex;
justify-content: center;
align-items: center;
border-radius: 2rem;
overflow: hidden; /* 防止 overlay 超出圆角*/
position: relative; /* 让 overlay 定位 */
z-index: 0; /* 阻止 overlay 的 z-index -1 去到更高层 */
&::after {
/* 黑色空 div, 填满整个 container */
content: "";
width: 100%;
height: 100%;
background-color: rgba($color: black, $alpha: 0.5);
/* 和 container 重叠 */
position: absolute;
top: 0;
left: 0;
z-index: -1; /* 必须小于 container 内其它元素 */
}
}
效果

搭配 Gradients
上面的 overlay 用的是 background-color, 这会让整张图都黑. 有时候我们字可能只是出现在左边.

这种情况就可以用 background-image: linear-gradient 替代
background-image: linear-gradient(to right, rgb(255 0 0 / 0.5), rgb(255 255 0 / 1));
Tips: background-image 支持 multiple, 所以我们甚至可以完全不用搞 ::after 定位那一套. 直接 background-image: gradient, url(...) 就可以了.
Overlay 居中
顺便教一个居中技巧.
<div class="container">
<div class="box"></div>
</div>
CSS Style
.container {
width: 500px;
height: 500px;
background-color: pink;
position: relative;
.box {
position: absolute;
inset: 0;
width: 100px;
height: 100px;
background-color: cyan;
margin: auto;
}
}
只要 box 有 dimension, 配上 inset 0 和 margin auto, box 就居中了
它和 top, left, transform 的效果是一样的
.box {
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
效果

第 2 种做法
参考: webflow 的一个模板
HTML 结构
<div class="container">
<h1>Hello World</h1>
<div class="overlay">
<img src="./images/tifa2.PNG" />
</div>
</div>
它不是用 container background-image 来做背景图, 而是用 <img>.
语义上来讲, 如果是要被 SEO 收入的, 那么用 <img> 是对的, 但如果它更倾向于背景图, 那么应该用 background-image.
img 和 background-image 还有个区别是 img 可以被 drag, 也可以被 save as, 而 background-image 是不可以的 (可以用 pointer-event:none 来阻止这项功能).

CSS Style
.container {
height: 100vh;
display: flex; /* 居中 h1 */
align-items: center;
justify-content: center;
h1 {
color: white;
font-size: 4rem;
}
position: relative;
.overlay {
background-color: black; /* 黑影是这样做出来的 */
img {
opacity: 0.7; /* 黑影是这样做出来的 */
width: 100%;
height: 100%;
object-fit: cover;
}
position: absolute;
inset: 0;
z-index: -1;
}
}
有两个点值得关注.
第一它实现黑影的方式是给 overlay background-color 黑色. 然后让 img opacity 0.7.
和第一个方案往图片盖一层黑影是颠倒的实现手法.
第二是它的 z-index
第一方案中, z-index: -1 让黑影下沉, 但是在 container 需要 z-index:0, 阻止 z-index 冒泡, 不然黑影就比 container 还底层而无法盖到 container 的 background-image 了.
第二方案中, container 不需要 z-index:0 去阻止 overlay 冒泡. 原因是 container 不负责 background-image. 所以即便 overlay 更底层也无所谓. 反正 container 是空心的.
它的层次是 h1 > container (空心) > overlay, 此时 mouse hover 接触的是 container 而不是 overlay.
但如果让 container 有一个 background-color, overlay 就被挡住了.

假设让 container z-index:0 阻止冒泡, 那么 <img> 就会在上层, h1 > overlay > container, 此时 mouse hover 接触的是 overlay 而不是 container.
也就是说, <img> 会被 drag 和 save as. 这时就需要用 pointer-event: none 来阻止了.
整体来看, 我不觉得方案二会比方案一好. 感觉它比较混乱. 没有那么直观.
CSS & JS Effect – Image Overlay的更多相关文章
- CSS & JS 制作滚动幻灯片
==================纯CSS方式==================== <!DOCTYPE html> <html> <head> <met ...
- 【转】Maven Jetty 插件的问题(css/js等目录死锁)的解决
Maven Jetty 插件的问题(css/js等目录死锁,不能自动刷新)的解决: 1. 打开下面的目录:C:\Users\用户名\.m2\repository\org\eclipse\jetty ...
- Css Js Loader For Zencart
Css Js Loader 描述:这个插件很早就出来了,可能知道人非常少 这个插件的功能是整合所有的网站的CSS和JS内容到一个文件里边. 因为CSS和JS文件到了一个文件,加快了程序的运行 在配合其 ...
- 购物车数字加减按钮HTML+CSS+JS(有需要嫌麻烦的小伙伴拿走不谢)
之前在写详情页的时候,如下图 因为自己嫌麻烦,就去看其他网站是怎么写的,想直接拿来用,后来看来看去觉得写得很麻烦,于是最后还是决定自己写,附上HTML+CSS+JS代码,一条龙一站式贴心服务2333 ...
- vs合并压缩css,js插件——Bundler & Minifier
之前做了一个大转盘的抽奖活动,因为比较火,部分用户反馈看不到页面的情况,我怀疑js加载请求过慢导致,所以今天针对之前的一个页面进行调试优化. 首先想到的是对页面的js和css进行压缩优化,百度了下vs ...
- nginx资源定向 css js路径问题
今天玩玩项目,学学nginx发现还不错,速度还可以,但是CSS JS确无法使用,原来Iginx配置时需要对不同类型的文件配置规则,真是很郁闷,不过想想也还是很有道理.闲暇之际,把配置贴上来.#user ...
- IIS7的集成模式下如何让自定义的HttpModule不处理静态文件(.html .css .js .jpeg等)请求
今天将开发好的ASP.NET站点部署到客户的服务器上后,发现了一个非常头疼的问题,那么就是IIS7的应用程序池是集成模式的话,ASP.NET项目中自定义的HttpModule会处理静态文件(.html ...
- 网站加载css/js/img等静态文件失败
网站加载css/js/img等静态文件失败,报网站http服务器内部500错误.而服务器中静态文件存在且权限正常. 从浏览器中直接访问文件,出来乱码.这种问题原因在于iis中该网站mime配置报错,不 ...
- 【前端】Sublime text3 插件HTML/CSS/JS prettify 格式化代码
1.首先安装插件 菜单的preference->packages control,然后输入install .. 回车,再输入HTML/CSS/JS prettify 再回车,重启后就可以了. 2 ...
- CSS+JS实现兼容性很好的无限级下拉菜单
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DT ...
随机推荐
- Azure Function 时区设置
一,引言 Azure Function 上的默认使用UTC 运行程序,我们在获取时间,或者通过时间执行某些逻辑时,返回UTC 时间,导致业务数据不正常,由于 Azure Function 是微软提供的 ...
- TokenObtainPairSerialize
TokenObtainPairSerializer是Django REST framework的SimpleJWT库提供的序列化器.它用于对用户凭据(如用户名和密码)进行序列化和验证,并在成功的身份验 ...
- [oeasy]python0120_英语的崛起_英文字符_小写字母的由来_不列颠帝国
各语言字符编码 回忆上次内容 罗马 承袭了 希腊的文化 学习了 希腊的字符 拥有 罗马帝国的战力 基督教文化的影响 添加图片注释,不超过 140 字(可选) 这个时候 不列颠 ...
- oeasy 教您玩转 linux 之 010301 电子宠物 pet
我们来回顾一下 上一部分我们都讲了什么? 中️文诗词fortune=zh的使用 建立自己的彩色诗词库 通过pip把输出结果交给cowsay或boxes 我们这次讲一讲桌面的一些应用 oneko 我们可 ...
- Day 9 - 线段树
线段树 引入 线段树是算法竞赛中常用的用来维护 区间信息 的数据结构. 线段树可以在 \(O(\log N)\) 的时间复杂度内实现单点修改.区间修改.区间查询(区间求和,求区间最大值,求区间最小值) ...
- Groovy 基于Groovy实现DES加解密
groovy 3.0.7 DES加密简介 加密分为对称加密和非对称加密.非对称加密,加解密使用不同的密钥,如RSA:对称加密,加解密使用相同的密钥,如DES(Data Encryption Stand ...
- CF941
A link 其实,只要有第一次,那么下次随意找一个队列里有的数加\(k-1\)个进去,加上队列里那一个删掉\(k\)个,到最后一次肯定是剩\(k-1\)个. 没有第一次,就是\(n\). 点击查看代 ...
- c++17 structure binding test
1 /*test for struct binding*/ 2 3 #include <string> 4 #include <iostream> 5 using namesp ...
- 简单聊聊WebDAV
1.什么是WebDAV? WebDAV是一种基于HTTP协议的扩展,旨在提供在Web服务器上进行文件管理的标准化解决方案.它允许用户通过网络对远程主机上的文件进行读写.编辑和删除操作.与传统的HTTP ...
- Pulsar客户端消费模式揭秘:Go 语言实现 ZeroQueueConsumer
前段时间在 pulsar-client-go 社区里看到这么一个 issue: import "github.com/apache/pulsar-client-go/pulsar" ...