分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > IT知识

CSS3实现多样的边框效果

发布时间:2023-09-06 01:52责任编辑:彭小芳关键词:CSS

半透明边框

实现效果:

实现代码:

<div>你能看到半透明的边框吗?</div>
div { ???/* 关键代码 */ ???border: 10px solid rgba(255,255,255,.5); ???background: white; ???background-clip: padding-box; ???????/* 其它样式 */ ???max-width: 20em; ???padding: 2em; ???margin: 2em auto 0; ???font: 100%/1.5 sans-serif;}

实现要点:

  • 设置边框为半透明,这是还看不到半透明边框,因为默认情况下,背景会延伸到边框所在的区域下层,也就是背景是被边框的外沿框裁切掉。
  • 通过设置 background-clip: padding-box (初始值是 border-box) 让背景不要延伸到边框所在的区域下层,也就是让内边距的外沿来裁切背景。

多重边框

实现效果:

实现代码:

<div></div>
/* box-shadow 实现方案 */div { ???/* 关键代码 */ ???box-shadow: 0 0 0 10px #655, ???????????0 0 0 15px deeppink, ???????????0 2px 5px 15px rgba(0,0,0,.6); ???????/* 其它样式 */ ???width: 100px; ???height: 60px; ???margin: 25px; ???background: yellowgreen;}/* border/outline 实现方案 */div { ???/* 关键代码 */ ???border: 10px solid #655; ???outline: 5px solid deeppink; ???????/* 其它样式 */ ???width: 100px; ???height: 60px; ???margin: 25px; ???background: yellowgreen;}

实现要点:

  • box-shadow 实现方案使用的是 box-shadow 的第四个参数(扩张半径)。一个正值的扩张半径加上两个为零的偏移量以及为零的模糊值,得到的“投影”其实就像一道实线边框。而借助 box-shadow 支持逗号分割语法,可创建任意数量的投影,因此我们就可实现多重边框效果。
  • border/outline 实现方案是使用 border 设置一层边框,再使用 outline 设置一层边框。这个方案可实现虚线边框,但它只能实现两层边框。

边框内圆角

实现效果:

实现代码:

<div>我有一个漂亮的内圆角</div>
div { ???outline: .6em solid #655; ???box-shadow: 0 0 0 .4em #655; /* 关键代码 */ ???????max-width: 10em; ???border-radius: .8em; ???padding: 1em; ???margin: 1em; ???background: tan; ???font: 100%/1.5 sans-serif;}

实现要点:

  • outline 不会跟着元素的圆角走(因而显示出直角),但 box-shadow 确实会的,因此,将两者叠加到一起,box-shadow(其扩张值大概等于 border-radius 值的一半) 会刚好填补 outline 和容器圆角之间的空隙,因此可达到我们想要的效果。

CSS3实现多样的边框效果

原文地址:https://www.cnblogs.com/laixiangran/p/8988090.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved