CSS3 实现发光边框特效


Posted in HTML / CSS onNovember 11, 2020

运行效果:

CSS3 实现发光边框特效

html

<!-- This element is not visible. The DOM is generated by JavaScript -->
<div class="root" style="display: none;">
  <div>
    <div class="side left"></div>
    <div class="side top"></div>
    <div class="side right"></div>
    <div class="side bottom"></div>
  </div>
</div>

CSS

body {
  margin: 0;
  width: 100vw;
  height: 100vh;
  background: #010326;
}

.root {
  --glow_width: 2px;
  --animation_length: 2s;
  --delay_factor: 2;

  position: absolute;
  left: 50%;
  top: 50%;
  width: 300px;
  height: 300px;
  transform: translate(-50%, -50%) rotate(45deg);

/*  Uncomment the line below to see how this system is set up  */
/*   border: 1px dashed red; */
  overflow: hidden;
}

.side {
  position: absolute;
  top: 0;
  left: 0;
}

.side.left,
.side.right {
  width: var(--glow_width);
  height: 0;
  background: linear-gradient(to bottom, transparent, #c03225, transparent);
  animation: heightAnim var(--animation_length) linear infinite,
    hider calc(var(--delay_factor) * var(--animation_length))
      var(--animation_length) infinite;
}

.side.top,
.side.bottom {
  width: 100%;
  height: var(--glow_width);
  background: linear-gradient(to left, transparent, #c03225, transparent);
  animation: widthAnim var(--animation_length) 0s linear infinite,
    hider calc(var(--delay_factor) * var(--animation_length))
      var(--animation_length) infinite;
}

.side.right {
  left: auto;
  right: 0;
  height: 0;
  animation-delay: calc(var(--animation_length) / 2);
  animation-direction: normal, reverse;
}

.side.bottom {
  top: auto;
  bottom: 0;
  width: 0;
  animation-delay: calc(var(--animation_length) / 2);
  animation-direction: normal, reverse;
}

@keyframes heightAnim {
  0% {
    height: 0px;
  }
  50% {
    height: 300px;
    transform: initial;
  }
  100% {
    transform: translate(0, 300px);
  }
}

@keyframes widthAnim {
  0% {
    width: 0px;
  }
  50% {
    width: 300px;
    transform: initial;
  }
  100% {
    transform: translate(300px, 0px);
  }
}

@keyframes hider {
  0%,
  50% {
    opacity: 0;
  }
  51%,
  100% {
    opacity: 1;
  }
}

js

let template = `<div class="root" style="transform: translate(-50%, -50%) rotate({{ value }})">
<div>
    <div class="side left"></div>
    <div class="side top"></div>
    <div class="side right"></div>
    <div class="side bottom"></div>
  </div>
</div>`

let segments = 9
for(let i = -segments; i < segments; i++){
  document.body.innerHTML += template.replace("{{ value }}", 90/segments * i + "deg")
}

// document.body.innerHTML += template.replace("{{ value }}", 90/segments * 0 + "deg")

以上就是CSS3 实现发光边框特效的详细内容,更多关于CSS3 发光边框特效的资料请关注三水点靠木其它相关文章!

HTML / CSS 相关文章推荐
纯CSS实现聊天框小尖角、气泡效果
Apr 04 HTML / CSS
CSS3的一个简单导航栏实现
Aug 03 HTML / CSS
css3的过滤效果简单实例
Aug 03 HTML / CSS
css3动画 小球滚动 js控制动画暂停
Nov 29 HTML / CSS
CSS3 文字动画效果
Nov 12 HTML / CSS
html5中如何将图片的绝对路径转换成文件对象
Jan 11 HTML / CSS
Html5无刷新修改browser Url的方法
Jan 15 HTML / CSS
HTML5新增元素如何兼容旧浏览器有哪些方法
May 09 HTML / CSS
浅谈移动端网页图片预加载方案
Nov 05 HTML / CSS
使用canvas压缩图片大小的方法示例
Aug 02 HTML / CSS
能用CSS实现的就不要麻烦JavaScript了
Oct 05 HTML / CSS
纯CSS如何禁止用户复制网页的内容
Nov 01 HTML / CSS
CSS 说明横向进度条最后显示文字的实现代码
Nov 10 #HTML / CSS
CSS3制作3D立方体loading特效
Nov 09 #HTML / CSS
CSS3实现莲花绽放的动画效果
Nov 06 #HTML / CSS
CSS3制作圆形滚动进度条动画的示例
Nov 05 #HTML / CSS
CSS实现进度条和订单进度条的示例
Nov 05 #HTML / CSS
一篇文章带你学习CSS3图片边框
Nov 04 #HTML / CSS
CSS3实现时间轴特效
Nov 02 #HTML / CSS
You might like
在PHP中执行系统外部命令
2006/10/09 PHP
PHP 操作文件的一些FAQ总结
2009/02/12 PHP
基于session_unset与session_destroy的区别详解
2013/06/03 PHP
PHP获取数组中重复最多的元素的实现方法
2014/11/11 PHP
PHP读取配置文件类实例(可读取ini,yaml,xml等)
2015/07/28 PHP
PHP实现登陆表单提交CSRF及验证码
2017/01/24 PHP
jquery焦点图片切换(数字标注/手动/自动播放/横向滚动)
2013/01/24 Javascript
查看图片(前进后退)功能实现js代码
2013/04/24 Javascript
JavaScript中的原型和继承详解(图文)
2014/07/18 Javascript
深入理解JavaScript系列(28):设计模式之工厂模式详解
2015/03/03 Javascript
Hammer.js+轮播原理实现简洁的滑屏功能
2016/02/02 Javascript
javascript深拷贝(deepClone)详解
2016/08/24 Javascript
Vue中的数据监听和数据交互案例解析
2017/07/12 Javascript
基于twbsPagination.js分页插件使用心得(分享)
2017/10/21 Javascript
node文件批量重命名的方法示例
2017/10/23 Javascript
vue.js图片转Base64上传图片并预览的实现方法
2018/08/02 Javascript
ajaxfileupload.js实现上传文件功能
2019/04/19 Javascript
js实现点击图片在屏幕中间弹出放大效果
2019/09/11 Javascript
在Express中提供静态文件的实现方法
2019/10/17 Javascript
vue中的计算属性和侦听属性
2020/11/06 Javascript
Vue中ref和$refs的介绍以及使用方法示例
2021/01/11 Vue.js
[15:57]教你分分钟做大人:斧王
2014/10/30 DOTA
Windows上配置Emacs来开发Python及用Python扩展Emacs
2015/11/20 Python
详解TensorFlow在windows上安装与简单示例
2018/03/05 Python
使用python存储网页上的图片实例
2018/05/22 Python
手写一个python迭代器过程详解
2019/08/27 Python
Python pandas RFM模型应用实例详解
2019/11/20 Python
python计算无向图节点度的实例代码
2019/11/22 Python
Selenium结合BeautifulSoup4编写简单的python爬虫
2020/11/06 Python
python程序实现BTC(比特币)挖矿的完整代码
2021/01/20 Python
内业资料员岗位职责
2014/01/04 职场文书
上课打牌的检讨书
2014/02/15 职场文书
2015年学校教育教学工作总结
2015/04/22 职场文书
Python 如何解决稀疏矩阵运算
2021/05/26 Python
SQL解决未能删除约束问题drop constraint
2022/05/30 SQL Server
JS函数式编程实现XDM一
2022/06/16 Javascript