【CSS】设置0.5px的边框宽度

直接写border: 0.5px solid red; 这样在移动端可能会出现问题,下面说下解决办法:

直接上代码:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .divClass {
            width: 100px;
            height: 100px;
            background-color: aquamarine;
            position: relative;
            margin-bottom: 20px;
            border-radius: 6px;
            /* border: 0.5px solid red; */
        }

        /* 方法1:上下左右都-50%,边框宽度和圆角都得扩大2倍,然后再用scale进行缩放 */
        .border1:after {
            content: '';
            position: absolute;
            top: -50%;
            bottom: -50%;
            left: -50%;
            right: -50%;
            border: 1px solid red;
            border-radius: 12px;
            -webkit-transform: scale(0.5);
            transform: scale(0.5);
        }

        /* 方法2:宽高都扩大两倍,然后再用scale进行缩放 */
        .border2:after {
            content: '';
            display: block;
            position: absolute;
            left: 0;
            top: 0;
            box-sizing: border-box;
            width: 200%;
            height: 200%;
            border: 1px solid red;
            border-radius: 12px;
            -webkit-transform: scale(0.5);
            transform: scale(0.5);
            transform-origin: 0 0;
        }

        .border3::after {
            /* 方法1: */
            content: "";
            display: block;
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 1px;
            background-color: red;
            -webkit-transform: scaleY(0.5);
            transform: scaleY(0.5);
            transform-origin: 0 0;

            /* 方法2: */
            /* content: "";
            display: block;
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 1px;
            background-color: red;
            -webkit-transform: scaleY(0.5);
            transform: scaleY(0.5);
            transform-origin: 0 0; */
        }
    </style>
</head>

<body>
    <div class="divClass border1">我有个0.5px的四条边框</div>
    <div class="divClass border2">我有个0.5px的四条边框</div>

    <div class="divClass border3">我有个0.5px的上边框</div>
</body>

</html>

在浏览器运行截图如下:

总结:目前推荐的是伪元素+tranform缩放的方法,相对灵活一点,可以针对不同元素进行设置。

参考文章:解决安卓不能识别border 0.5px问题_安卓 0.5px-CSDN博客

超全面的解决0.5px边框问题_多出0.5px-CSDN博客

0.5px的边框线遇到的坑_pc端网页有没有0.5的border-CSDN博客

当你设置0.5px的边框宽度时... - 掘金

相关推荐
雾散声声慢5 分钟前
前端开发中怎么把链接转为二维码并展示?
前端
熊的猫6 分钟前
DOM 规范 — MutationObserver 接口
前端·javascript·chrome·webpack·前端框架·node.js·ecmascript
天农学子6 分钟前
Easyui ComboBox 数据加载完成之后过滤数据
前端·javascript·easyui
mez_Blog7 分钟前
Vue之插槽(slot)
前端·javascript·vue.js·前端框架·插槽
爱睡D小猪9 分钟前
vue文本高亮处理
前端·javascript·vue.js
开心工作室_kaic12 分钟前
ssm102“魅力”繁峙宣传网站的设计与实现+vue(论文+源码)_kaic
前端·javascript·vue.js
放逐者-保持本心,方可放逐13 分钟前
vue3 中那些常用 靠copy 的内置函数
前端·javascript·vue.js·前端框架
IT古董13 分钟前
【前端】vue 如何完全销毁一个组件
前端·javascript·vue.js
Henry_Wu00115 分钟前
从swagger直接转 vue的api
前端·javascript·vue.js
SameX25 分钟前
初识 HarmonyOS Next 的分布式管理:设备发现与认证
前端·harmonyos