【css】实现扫光特效

对于要重点突出的元素,我们经常可以看到它上面打了一个从左到右的斜向扫光,显得元素亮闪闪的!类似于下图的亮光动效

关键步骤

  • 伪元素设置position :absolute【也可以不用伪元素,直接创建一个absolute元素盖在上面
  • 设置渐变linear-gradient背景色
  • 设置透明度
  • 将元素transform :skewX(..),在水平方向上设置畸变压缩。可参考https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/skewX
  • 设置扫动动画的keyframe,控制该定位元素的left变化

实现方法

假设我要在class="container"的盒子元素上设置扫光特效,可以用如下css代码实现:

css 复制代码
//container
.container {
    width: 44vw;
    height: 16vh;
    border-radius: 8px;
    border: 1px solid red;
    background-color: black;
}

//扫光伪元素
.container::before {
    content: '';
    z-index: 999;

    //伪元素默认是 display:inline
    display: inline-block;
    position: absolute;
    left: 0;
    top: 0;

    width: 30vw;
    height: 16vh;
    //让光斜着扫
    transform: skewX(135deg);

    opacity: 0.2;
    background: linear-gradient(246.64deg, rgba(255, 255, 255, 0) 30.82%, #ffffff 45.23%, #ffffff 56.8%, rgba(255, 255, 255, 0) 70.24%);
    
    //animation: 关键帧名 执行delay fill-mode 重复次数
    animation: move-light 3s both infinite;
}



@keyframes move-light {
  0% {
    left: -50%;
  }
  100% {
    left: 125%;
  }
}

值得一提的是:设置animation中的fill-mode为both之后,扫光立马应用上了第一个style配置"left:-50%",使其从指定位置开始运动

具体使用方法可见:https://developer.mozilla.org/en-US/docs/Web/CSS/animation-fill-mode

相关推荐
今天不要写bug11 分钟前
基于elementUI实现一个可编辑的表格(简洁版)
前端·javascript·elementui
上优14 分钟前
Vue3纯前端同源跨窗口通信移动AGV小车
前端·vue.js·状态模式
h_k1008614 分钟前
Chrome 插件开发入门技术文章大纲
前端·chrome
一只小阿乐15 分钟前
vue-router 的实现原理
前端·javascript·vue.js·路由·vue-router
Zz_waiting.15 分钟前
案例开发 - 日程管理 - 第七期
开发语言·前端·javascript·vue.js·html·路由
一只小风华~19 分钟前
Vue:事件处理机制详解
前端·javascript·vue.js·typescript·前端框架
dy17174 小时前
element-plus表格默认展开有子的数据
前端·javascript·vue.js
2501_915918418 小时前
Web 前端可视化开发工具对比 低代码平台、可视化搭建工具、前端可视化编辑器与在线可视化开发环境的实战分析
前端·低代码·ios·小程序·uni-app·编辑器·iphone
程序员的世界你不懂8 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
索迪迈科技8 小时前
网络请求库——Axios库深度解析
前端·网络·vue.js·北京百思可瑞教育·百思可瑞教育