用 CSS 实现自定义虚线边框

发布于 2022-06-30 14:53:08 字数 964 浏览 1202 评论 1

开发产品功能的时候ui往往会给出虚线边框的效果图,于是乎,我们往往第一时间想到的是用css里的border,可是border里一般就提供两种效果,dashed 或者 dotted,ui 这时就不满意了,说虚线太密了。废话不多说,下面直接给解决方案:

div {
    padding: 1em;
    border: 1px dashed transparent;
    background: linear-gradient(white,white) padding-box,
    repeating-linear-gradient(-45deg,#ccc 0, #ccc 0.25em,white 0,white 0.75em);
}

基本效果如下:

在线实例:https://www.wenjiangs.com/runcode?slug=TPKQFuQn

以上的基本原理是通过两层线性渐变背景去覆盖,第一层是在 padding-box 容器内(及虚线边框的容器内的白色部分,如果换成 border-box 那肯定把虚线也覆盖了),用这一层去覆盖 repeating-linear-gradient 生成的条纹背景。具体的虚线的颜色和间距都可以通过 repeating-linear-gradient 生成的条纹背景去调整。最后给出 linear-gradient 支持的浏览器,要使用的话请权衡。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

风为裳 2022-05-01 14:51:36

that's great

~没有更多了~

关于作者

宁愿没拥抱

暂无简介

0 文章
0 评论
23 人气
更多

推荐作者

已经忘了多久

文章 0 评论 0

15867725375

文章 0 评论 0

LonelySnow

文章 0 评论 0

走过海棠暮

文章 0 评论 0

轻许诺言

文章 0 评论 0

信馬由缰

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文