【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的边框宽度时... - 掘金

相关推荐
ganshenml9 分钟前
sed 流编辑器在前端部署中的作用
前端·编辑器
0***K8921 小时前
Vue数据挖掘开发
前端·javascript·vue.js
蓝胖子的多啦A梦1 小时前
ElementUI表格错位修复技巧
前端·css·vue.js·el-table表格错位
_OP_CHEN1 小时前
前端开发实战深度解析:(一)认识前端和 HTML 与开发环境的搭建
前端·vscode·html·web开发·前端开发
喂自己代言1 小时前
HTML ``元素:链接外部资源的关键角色与用法
css·html
xiAo_Ju1 小时前
iOS一个Fancy UI的Tricky实现
前端·ios
H***99761 小时前
Vue深度学习实战
前端·javascript·vue.js
猴猴不是猴2 小时前
js实现卷轴,中间可滑动方块,左右两侧对比
javascript·css·css3
toooooop82 小时前
Vuex 中 state、mutations 和 actions 的原理和写法
前端·javascript·uni-app
y***86692 小时前
前端CSS-in-JS方案
前端·javascript·css