用CSS画一条0.5px的线

上次面试前端被问到了这个问题,感觉有点懵懵的,我就回答了一个scaleY(0.5),这个是真的没想到,希望有需要的朋友可以去看看。随便记住一种就行。

1.第一种方式:通过缩放1px的线条实现视觉上的0.5px效果,兼容性较好。

复制代码
.thin-line {
  position: relative;
}

.thin-line::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px; /* 初始高度1px */
  background: #000;
  transform: scaleY(0.5); /* 垂直缩放至0.5倍 */
  transform-origin: 0 0; /* 确保缩放基点正确 */
}

2.第二种方式:直接使用0.5px边框(现代浏览器)

复制代码
.thin-border {
  border-bottom: 0.5px solid #000;
}

3.第三种方式:使用transform缩放(推荐) 结合媒体查询(适配高分辨率屏幕)

复制代码
.thin-line::after {
  content: '';
  /* ...同方法1... */
}

/* 高分辨率设备直接使用0.5px */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .thin-line::after {
    border-bottom: 0.5px solid #000;
    transform: none; /* 禁用缩放 */
  }
}

4.第四种方式:线性渐变:创建极细渐变模拟线条,适合简单场景。

复制代码
.thin-gradient {
  background: linear-gradient(to bottom, #000 50%, transparent 50%);
  height: 1px;
  transform: scaleY(0.5);
}

5.第五种方式:​box-shadow:利用微小阴影模拟线条。

复制代码
.thin-shadow {
  box-shadow: 0 0.5px 0 #000;
}
相关推荐
kyriewen4 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒4 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
山河木马5 小时前
矩阵专题2-怎么创建视图矩阵(uViewMatrix)
javascript·webgl·计算机图形学
小林攻城狮5 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦5 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer5 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队5 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY5 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_6 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏6 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端