Retina屏实现1像素

TIP

实际运用中,我会用box-shadow实现矩形四边线框一像素,而用transform搭配before、after伪类的形式实现单独一边的一像素。目前来看,可以适用绝大部分业务场景。

transform:scale(0.5)

实现方式:

height:1px;
-webkit-transform: scaleY(0.5);
-webkit-transform-origin:0 0;
overflow: hidden;
1
2
3
4

此方案配合:after和:before独立使用较多,比如画一个商品的边框四条线,容器的after和before可以画2条线,利用容器的父元素的after、before再画2条线。

.after-scale{
  position: relative;
}
.after-scale:after{
  content:"";
  position: absolute;
  bottom:0px;
  left:0px;
  right:0px;
  border-bottom:1px solid #c8c7cc;
  -webkit-transform:scaleY(.5);
  -webkit-transform-origin:0 0;
}
1
2
3
4
5
6
7
8
9
10
11
12
13

四边1像素border

.scale{
  position:relative;
}
.scale:before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:200%;
  height:200%;
  border:1px solid #dadada;
  box-sizing:border-box;
  transform: scale(0.5);
    -webkit-transform: scale(0.5);
    transform-origin: 0 0;
    -webkit-transform-origin: 0 0;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

box-shadow

实现方式:

利用css 对阴影处理的方式实现0.5px的效果

  1. 底部一条线
-webkit-box-shadow:0 1px 1px -1px rgba(0, 0, 0, 0.5);
1
  1. 顶部一条线
box-shadow: 0 -1px 1px -1px rgba(0, 0, 0, 0.5);
1

基本所有场景都能满足,包含圆角的button,单条,多条线;但是颜色不好处理,黑色rgba(0,0,0,1)最浓的情况了。有的浏览器会有阴影出现,不好用。

background-image

实现方式:

设置1px通过css 实现的image,50%有颜色,50%透明

.border {
  background-image:linear-gradient(180deg, red, red 50%, transparent 50%),
  linear-gradient(270deg, red, red 50%, transparent 50%),
  linear-gradient(0deg, red, red 50%, transparent 50%),
  linear-gradient(90deg, red, red 50%, transparent 50%);
  background-size: 100% 1px,1px 100% ,100% 1px, 1px 100%;
  background-repeat: no-repeat;
  background-position: top, right top,  bottom, left top;
  padding: 10px;
  }
1
2
3
4
5
6
7
8
9
10

配合background-image,background-size,background-position可以实现单条、多条边框,边框的颜色随意设置;但如果有圆角的效果,很sorry圆角的地方没有线框的颜色,且要写的代码也不少。

图片

实现方式:

.border-image{
  border-image:url("") 2 0 stretch;
  border-width: 0px 0px 1px;
}
1
2
3
4

可以通过修改图片来达到圆角的效果,但是由于图片的原因,压缩过后的图片边缘变模糊了(不放大的情况下不明显),需要引用图片或者base64,边框颜色修改起来不方便。

参考: stackoverflow

上次更新: 2018-9-9 17:00:48