前端萌新别慌:30分钟搞懂CSS border所有属性(附超全示例代码)
- 前端萌新别慌:30分钟搞懂CSS border所有属性(附超全示例代码)
- 先给border做个“人口普查”
- 最原始的三件套:width-style-color
- 方向四兄弟:top right bottom left
- border-style 的十连抽
- border-width 的“三挡自动”
- border-color 也能玩透明与渐变
- border-radius:圆角、椭圆、胶囊、不规则
- 盒模型爆炸现场:border撑大布局
- 表格里的border-collapse:合并 or 分离
- 骚操作1:border画三角形
- 骚操作2:border旋转loading
- 1px边框在移动端变粗?——“物理像素”背锅
- border-image:把边框换成图,但IE劝退
- 调试神器:临时荧光border
- SCSS变量统一边框设计token
- 设计师给的“微妙灰”到底取哪个?
- flex/grid里border会抽风吗?
- 兼容性老坑合集
- 面试官:不用图标,纯CSS画对话框?
- 彩蛋:border+clip-path做“动态缺口”
- 收尾吐槽
前端萌新别慌:30分钟搞懂CSS border所有属性(附超全示例代码)
——“哥,我一行border:1px solid #000写到吐,可面试官还是嫌我土,怎么办?”
——“别急,今天咱们把border扒到只剩底裤,顺带用代码给它化个妆,30分钟后你就拿着新简历去反杀。”
先给border做个“人口普查”
别看这哥们名字短,户口本可长了。官方登记的有:
- border-width 边框多粗
- border-style 边框长啥样
- border-color 边框啥颜色
- border-radius 圆角还是方角
- border-image 把边框换成图(兼容屎山预警)
再加上方向四兄弟:top、right、bottom、left,每个都能单独领一份属性。
算一下,理论上限 5×4=20 个属性,再乘上简写、复合、继承、初始值……
——“停停停,哥,我CPU烧了!”
放心,下面咱们用人类语言过一遍,烧不了一点。
最原始的三件套:width-style-color
先整一个“工地围挡”热热身:
<divclass="box">我是一条没有感情的边框</div><style>.box{width:200px;height:80px;border-width:8px;/* 多粗 */border-style:solid;/* 实线 */border-color:#ff4d4f;/* 猛男粉 */}</style>写完一看,嚯,红得发紫,老板以为报错。
其实三兄弟能一次性合体:
border:8px solid #ff4d4f;合体技省键盘,但别急着爽,下面有坑。
方向四兄弟:top right bottom left
有时候只想给下边加条“刘海”,其它三边别凑热闹。
最耿直写法:
border-top:3px dashed #09f;border-right:none;/* 直接让它消失 */border-bottom:6px double #333;border-left:12px dotted hotpink;也可以把四兄弟拉到一个群里,用空格一次@全体:
border-width:1px 2px 3px 4px;/* 上 右 下 左 */border-style:solid dashed dotted double;border-color:red green blue yellow;记忆口诀:从12点钟方向顺时针转一圈,和margin、padding一个尿性。
——“哥,我逆时针写的能跑吗?”
能跑,浏览器只会当你写错了,然后悄悄帮你“纠正”,跑是跑,就是心里膈应。
border-style 的十连抽
官方给出的合法值一共10个,来,张嘴接好:
solid | dashed | dotted | double | groove | ridge | inset | outset | hidden | nonenone和hidden最容易搞混:
none——直接拆边框,占位0,布局当它不存在。hidden——占着茅坑不拉屎,布局占位还在,就是看不见。
下面这段代码挨个给你看脸:
<divclass="row"><spanclass="s solid">solid</span><spanclass="s dashed">dashed</span><spanclass="s dotted">dotted</span><spanclass="s double">double</span><spanclass="s groove">groove</span></div><style>.row{display:flex;gap:10px}.s{padding:6px 12px;border-width:4px;border-color:#333;}.s.solid{border-style:solid}.s.dashed{border-style:dashed}……/* 其余同理 */</style>放大看dotted,圆点居然不是正圆?——“浏览器祖传像素对齐bug,别纠结,纠结就是10年寿命。”
border-width 的“三挡自动”
除了写固定px,CSS还给你三个模糊词:thin、medium、thick。
具体对应多少px?——“看浏览器心情”。
实测Chrome:thin≈1px,medium≈3px,thick≈5px。
做像素级还原时千万别用,设计稿会拿刀追你九条街。
/* 感受一下“自动挡” */.auto-border{border:thick ridge #ffcc00;}border-color 也能玩透明与渐变
透明?so easy:
border-color:rgba(255,0,0,.3);/* 50%透明红 */border-color:transparent;/* 全隐形,但占位 */渐变?标准里其实没说border-color支持linear-gradient,但你可以曲线救国——border-image,后面讲。
先给颗糖:用currentColor让边框自动跟字体色走,少写一行是一行。
button{color:#1890ff;border:1px solid currentColor;/* 改文字色即可联动 */}border-radius:圆角、椭圆、胶囊、不规则
最基础:
border-radius:8px;/* 四角统一 */想玩花?先上50%整胶囊:
.pill{height:40px;padding:0 20px;border-radius:20px;/* 高度一半 */}再来椭圆:当宽高不一样,50%就是椭圆本椭。
.ellipse{width:120px;height:60px;border-radius:50%;}四值拆分:
border-radius:10px 20px 30px 40px / 5px 10px 15px 20px;/* “/”前是水平半径,后是垂直半径,别被吓到,就是椭圆方程 */斜角切:
clip-path:polygon(0 0,100% 0,100%calc(100% - 20px),calc(100% - 20px)100%,0 100%);/* 配合border,纯CSS就能做“优惠券”撕角 */盒模型爆炸现场:border撑大布局
默认box-sizing: content-box;
你给200×200的盒子加border:10px,实际尺寸220×220。
一行代码治百病:
*{box-sizing:border-box;}从此以后,写死width:100%再随便加border,妈妈再也不担心我被设计师打。
表格里的border-collapse:合并 or 分离
<tableclass="a"><tr><td>1</td><td>2</td></tr><tr><td>3</td><td>4</td></tr></table><style>.a{border-collapse:collapse}/* 合并模式 */.a td{border:1px solid #333}</style>collapse模式下,相邻边框会合并,粗细取最大那条;
separate模式则各走各的,还能加border-spacing控制缝隙。
——“哥,我就想要0.5px的缝!”
醒醒,border-spacing最小1px,0.5px得用transform:scale(.5)伪类,别把自己卷死。
骚操作1:border画三角形
原理:把width、height设为0,让四边边框互相挤,只留一条边有色。
.triangle{width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:15px solid #ff4d4f;}想朝右?把bottom换成left,再把颜色换到right,自己转方向。
升级:聊天气泡小尾巴
.bubble{position:relative;padding:10px 15px;background:#fff;border:1px solid #ddd;border-radius:6px;}.bubble::after{content:'';position:absolute;bottom:-8px;left:20px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:8px solid #fff;/* 和背景同色 */}.bubble::before{content:'';position:absolute;bottom:-9px;left:20px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:9px solid #ddd;/* 边框色 */}双层三角,阴影+边框全搞定,老前端看了都说内行。
骚操作2:border旋转loading
<divclass="loader"></div><style>.loader{width:40px;height:40px;border:4px solidrgba(0,0,0,.1);border-top-color:#09f;/* 只留上边有色 */border-radius:50%;animation:spin .6s linear infinite;}@keyframesspin{to{transform:rotate(360deg)}}</style>一行标签+十行CSS,比gif省流量,比lottie省bundle,性能yyds。
1px边框在移动端变粗?——“物理像素”背锅
假设设备像素比dpr=2,UI要你1px,CSS写1px,实际渲染2物理像素,看上去就“粗”。
主流hack:transform缩小一半
.hairline{position:relative;}.hairline::after{content:'';position:absolute;left:0;bottom:0;width:100%;height:1px;background:#ddd;transform:scaleY(.5);transform-origin:bottom;}dpr=3就scaleY(.33),写个mixin自动判断:
@mixin hairline($dir:bottom,$color:#ddd){ position:relative; &::after{ content:''; position:absolute; #{$dir}:0; left:0; #{if($dir==left or $dir==right,width,height)}:1px; background:$color; transform:#{if($dir==left or $dir==right,'scaleX','scaleY')}(.5); transform-origin:#{$dir}; } }border-image:把边框换成图,但IE劝退
.fancy{border:20px solid;border-image:url("frame.png")30 round;}语法:slice / width / outset / repeat,四个参数堪比天书;
IE11只支持老式语法,想兼容得再写一套fallback。
结论:除非设计师拿刀架脖子,否则能用border-radius+background模拟就别碰border-image。
调试神器:临时荧光border
*{border:1px solid #0f0!important;}一行代码,全站变“绿巨人”,元素边界瞬间现形,调完即删,谁用谁知道。
——“哥,生产环境忘了删怎么办?”
那就准备社死,绿色边框配红error,圣诞风提前上线。
SCSS变量统一边框设计token
$border-color-light:#ebebeb; $border-color-base:#d9d9d9; $border-color-dark:#bfbfbf; $border-radius-sm:2px; $border-radius:4px; $border-radius-lg:8px; .btn{ border:1px solid $border-color-base; border-radius:$border-radius; }换主题?改变量一键同步,比全局搜索replace靠谱一万倍。
设计师给的“微妙灰”到底取哪个?
用吸管工具一吸,#eeeeee,看似完美,放到深色背景直接“高亮”。
正确姿势:让设计师给透明度,用rgba写死:
border-color:rgba(0,0,0,.08);/* 任何背景都能融合 */flex/grid里border会抽风吗?
不会,它们只负责布局,不抢border饭碗。
但要注意gap和border同时存在时,视觉间距会叠加;
做“中间分隔线”时,直接用gap+伪类即可,别给每个item写右边框再last-child:none,太蠢。
兼容性老坑合集
- IE6/7:dotted渲染成dashed,圆角直接罢工——“用图片垫背”。
- 安卓4.3:border-radius+background渐变,圆角外侧出现毛边——“background-clip:padding-box”可救。
- Safari:border-image+round,偶尔出现“裁图不对齐”——“加transform:translateZ(0)强刷图层”。
面试官:不用图标,纯CSS画对话框?
甩他脸上:
<divclass="dialog">今天面试稳了</div><style>.dialog{position:relative;width:200px;padding:12px;background:#fff;border:1px solid #ddd;border-radius:6px;}.dialog::before{content:'';position:absolute;left:-8px;top:16px;width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-right:8px solid #ddd;}.dialog::after{content:'';position:absolute;left:-7px;top:16px;width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-right:8px solid #fff;}</style>双层三角,边框+背景完美对齐,面试官点头如捣蒜。
彩蛋:border+clip-path做“动态缺口”
.cut{width:200px;height:60px;border:2px solid #09f;clip-path:polygon(0 0,100% 0,100% 75%,75% 100%,0 100%);transition:clip-path .3s;}.cut:hover{clip-path:polygon(0 0,100% 0,100% 100%,0 100%);}鼠标滑过,缺口瞬间“长回去”,纯CSS,零JS,绩效+1。
收尾吐槽
border这货,就像小区门卫:天天见,觉得人家普通;真出事,才发现它啥都能干。
今天30分钟带你撸完20+属性、10来个骚操作,代码直接复制就能跑。
别再放收藏夹吃灰,现在立刻马上打开VSCode,敲一遍,下回面试把border甩面试官脸上——
“哥,边框自由,我已经拿到了,薪资条也该涨涨吧?”
欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。
推荐:DTcode7的博客首页。
一个做过前端开发的产品经理,经历过睿智产品的折磨导致脱发之后,励志要翻身农奴把歌唱,一边打入敌人内部一边持续提升自己,为我们广大开发同胞谋福祉,坚决抵制睿智产品折磨我们码农兄弟!
| 专栏系列(点击解锁) | 学习路线(点击解锁) | 知识定位 |
|---|---|---|
| 《微信小程序相关博客》 | 持续更新中~ | 结合微信官方原生框架、uniapp等小程序框架,记录请求、封装、tabbar、UI组件的学习记录和使用技巧等 |
| 《AIGC相关博客》 | 持续更新中~ | AIGC、AI生产力工具的介绍,例如stable diffusion这种的AI绘画工具安装、使用、技巧等总结 |
| 《HTML网站开发相关》 | 《前端基础入门三大核心之html相关博客》 | 前端基础入门三大核心之html板块的内容,入坑前端或者辅助学习的必看知识 |
| 《前端基础入门三大核心之JS相关博客》 | 前端JS是JavaScript语言在网页开发中的应用,负责实现交互效果和动态内容。它与HTML和CSS并称前端三剑客,共同构建用户界面。 通过操作DOM元素、响应事件、发起网络请求等,JS使页面能够响应用户行为,实现数据动态展示和页面流畅跳转,是现代Web开发的核心 | |
| 《前端基础入门三大核心之CSS相关博客》 | 介绍前端开发中遇到的CSS疑问和各种奇妙的CSS语法,同时收集精美的CSS效果代码,用来丰富你的web网页 | |
| 《canvas绘图相关博客》 | Canvas是HTML5中用于绘制图形的元素,通过JavaScript及其提供的绘图API,开发者可以在网页上绘制出各种复杂的图形、动画和图像效果。Canvas提供了高度的灵活性和控制力,使得前端绘图技术更加丰富和多样化 | |
| 《Vue实战相关博客》 | 持续更新中~ | 详细总结了常用UI库elementUI的使用技巧以及Vue的学习之旅 |
| 《python相关博客》 | 持续更新中~ | Python,简洁易学的编程语言,强大到足以应对各种应用场景,是编程新手的理想选择,也是专业人士的得力工具 |
| 《sql数据库相关博客》 | 持续更新中~ | SQL数据库:高效管理数据的利器,学会SQL,轻松驾驭结构化数据,解锁数据分析与挖掘的无限可能 |
| 《算法系列相关博客》 | 持续更新中~ | 算法与数据结构学习总结,通过JS来编写处理复杂有趣的算法问题,提升你的技术思维 |
| 《IT信息技术相关博客》 | 持续更新中~ | 作为信息化人员所需要掌握的底层技术,涉及软件开发、网络建设、系统维护等领域的知识 |
| 《信息化人员基础技能知识相关博客》 | 无论你是开发、产品、实施、经理,只要是从事信息化相关行业的人员,都应该掌握这些信息化的基础知识,可以不精通但是一定要了解,避免日常工作中贻笑大方 | |
| 《信息化技能面试宝典相关博客》 | 涉及信息化相关工作基础知识和面试技巧,提升自我能力与面试通过率,扩展知识面 | |
| 《前端开发习惯与小技巧相关博客》 | 持续更新中~ | 罗列常用的开发工具使用技巧,如 Vscode快捷键操作、Git、CMD、游览器控制台等 |
| 《photoshop相关博客》 | 持续更新中~ | 基础的PS学习记录,含括PPI与DPI、物理像素dp、逻辑像素dip、矢量图和位图以及帧动画等的学习总结 |
| 日常开发&办公&生产【实用工具】分享相关博客》 | 持续更新中~ | 分享介绍各种开发中、工作中、个人生产以及学习上的工具,丰富阅历,给大家提供处理事情的更多角度,学习了解更多的便利工具,如Fiddler抓包、办公快捷键、虚拟机VMware等工具 |
吾辈才疏学浅,摹写之作,恐有瑕疵。望诸君海涵赐教。望轻喷,嘤嘤嘤
非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。愿斯文对汝有所裨益,纵其简陋未及渊博,亦足以略尽绵薄之力。倘若尚存阙漏,敬请不吝斧正,俾便精进!