1px 问题指的是:在一些 Retina 屏幕 的机型上,移动端页面的 1px 会变得很粗,呈现出不止 1px 的效果。原因很简单——CSS 中的 1px并不能和移动设备上的 1px 划等号。它们之间的比例关系有一个专 门的属性来描述:
window.devicePixelRatio = 设备的物理像素/css像素
打开 Chrome 浏览器,启动移动端调试模式,在控制台去输出这个 devicePixelRatio 的值。这里选中 iPhone6/7/8 这系列的机型,输 出的结果就是 2:
这就意味着设置的 1px CSS 像素,在这个设备上实际会用 2 个物理 像素单元来进行渲染,所以实际看到的一定会比 1px 粗一些。
思路一:直接写 0.5px
思路二:伪元素先放大后缩小