移动端1px问题处理方法

在做移动端开发时,设计师提供的视觉稿一般是750px,当你定义 border-width:1px 时,在iphone6手机上却发现:边框变粗了。。

这是因为,1px是相对于750px的(物理像素),而我们定义的1px是相对于375px的(css像素)“实际上应该是border-width:0.5px”。

解决方法:

1、border-image 图片 实现

在使用 border-image 时,将border设计为物理1px,如下:

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

也可以直接使用 base64 :

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

2、使用background-image实现

background-image 跟 border-image 的方法一样,根据我们定义的图片将边框模拟在背景上。

.background-image-1px {
    background: url(../img/line.png) repeat-x left bottom;
    -webkit-background-size: 100% 1px;
    background-size: 100% 1px;
}

3、多背景渐变实现

将上述方法中的图片替换为 css3 渐变。设置1px的渐变背景,50%有颜色,50%透明。

.background-gradient-1px {
  background:
    linear-gradient(180deg, black, black 50%, transparent 50%) top left / 100% 1px no-repeat,
    linear-gradient(90deg, black, black 50%, transparent 50%) top right / 1px 100% no-repeat,
    linear-gradient(0, black, black 50%, transparent 50%) bottom right / 100% 1px no-repeat,
    linear-gradient(-90deg, black, black 50%, transparent 50%) bottom left / 1px 100% no-repeat;
}
/* 或者 */
.background-gradient-1px{
    background: -webkit-gradient(linear, left top, left bottom, color-stop(.5, transparent), color-stop(.5, #c8c7cc), to(#c8c7cc)) left bottom repeat-x;
    background-size: 100% 1px;
}

4、使用box-shadow模拟边框

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

.box-shadow-1px {
    box-shadow: inset 0px -1px 1px -1px #c8c7cc;
}

5、viewport+rem实现

该方法是使用 viewport+rem+js 来实现的,可以直接设置1px就行了,而且圆角什么的都没问题。

<span style="font-size:18px;"><html>
    <head>
        <title>1px question</title>
        <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
        <meta name="viewport" id="WebViewport" content="initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">
        <style>
            html {
                font-size: 1px;
            }
            * {
                padding: 0;
                margin: 0;
            }  

            .bds_b {
                border-bottom: 1px solid #ccc;
            }  

            .a,
            .b {
                margin-top: 1rem;
                padding: 1rem;
                font-size: 1.4rem;
            }  

            .a {
                width: 30rem;
            }  

            .b {
                background: #f5f5f5;
                width: 20rem;
            }
        </style>
        <script>  

            var viewport = document.querySelector("meta[name=viewport]");
            //下面是根据设备像素设置viewport
            if (window.devicePixelRatio == 1) {
                viewport.setAttribute(‘content‘, ‘width=device-width,initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no‘);
            }
            if (window.devicePixelRatio == 2) {
                viewport.setAttribute(‘content‘, ‘width=device-width,initial-scale=0.5, maximum-scale=0.5, minimum-scale=0.5, user-scalable=no‘);
            }
            if (window.devicePixelRatio == 3) {
                viewport.setAttribute(‘content‘, ‘width=device-width,initial-scale=0.3333333333333333, maximum-scale=0.3333333333333333, minimum-scale=0.3333333333333333, user-scalable=no‘);
            }
            var docEl = document.documentElement;
            var fontsize = 10 * (docEl.clientWidth / 320) + ‘px‘;
            docEl.style.fontSize = fontsize;  

        </script>
    </head>
    <body>
        <div class="bds_b a">下面的底边宽度是虚拟1像素的</div>
        <div class="b">上面的边框宽度是虚拟1像素的</div>
    </body>
</html></span>

6、伪类 + transform 实现

我们可以通过缩放来实现上面的效果:

@mixin bd-all-1px($bStyle, $color, $radius) {
	position: relative;
	&:after {
		content: ‘‘;
		position: absolute;
		top: 0;
		left: 0;
		width: 200%;
		height: 200%;
		box-sizing: border-box;
		transform: scale(0.5);
		transform-origin: left top;
		border: 1px $bStyle $color;
		border-radius: $radius;
	}
} 

这种方法还可以实现圆角,transform: scale(0.5);中的0.5是这样计算来的,一般设计师提供的都是二倍图,以iphone6为例,其屏幕宽度 375,设计稿是750 ,375/750=0.5;如果是三倍图,就应该是scale(0.333333)了。

参考资料:

1、https://github.com/AlloyTeam/Mars/blob/master/solutions/border-1px.md

2、https://juejin.im/entry/584e427361ff4b006cd22c7c

原文地址:https://www.cnblogs.com/sunLemon/p/10775551.html

时间: 2024-10-10 20:01:28

移动端1px问题处理方法的相关文章

html移动端1px细线解决方案汇总

现在的PM和UI总以看app的眼光看html5, html页面要做的专业美观,而且必须很精细. 去年的时候UI就告诉我h5上的边框线太粗,把整站都给拉low了. 当时工期紧就没太在意1px粗细, 好在那个版本没上线就迭代掉了,后面的版本针对这个问题做了些尝试, 这里总结下1px细线的处理方法 移动端1px变粗的原因 为什么移动端css里面写了1px, 实际看起来比1px粗. 其实原因很好理解:这2个'px'的含义是不一样的. 移动端html的header总会有一句 <meta name="

移动端 1px边框 问题

https://segmentfault.com/a/1190000015736900 https://blog.csdn.net/yexudengzhidao/article/details/98480173 本文介绍了解决移动端1px边框问题的5种方法.当然了,在这之前先整理了与这些方法相关的知识:物理像素.设备独立像素.设备像素比和viewport. 物理像素.设备独立像素和设备像素比 在CSS中我们一般使用px作为单位,需要注意的是,CSS样式里面的px和物理像素并不是相等的.CSS中的

移动端1px细线解决方案总结

移动端1px变粗的原因 为什么移动端css里面写了1px, 实际看起来比1px粗. 其实原因很好理解:这2个'px'的含义是不一样的. 移动端html的header总会有一句 <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no"> 这句话定义了本页面的viewport的宽度为设备宽度,初始缩放值和

移动端图片上传方法【更好的兼容安卓IOS和微信】

之前的移动端上传的方法,有些朋友测试说微信支持不是很好,还有部分安卓机也不支持,其实我已经有了另一个方法,但是例子还没整理出来,而联系我的很多朋友需要,所以就提前先发出来了,并且做一个简单的说明,就不做一个demo了. <!doctype html>  <html>  <head>  <meta charset="utf-8">  <meta name="viewport" content="width

IE/Chrome背景图片居中1px偏移解决方法

最近在支持行业运营的一个推广页面,遇到了非常规的页面banner图居中的问题,为了解决此问题,做了简单的测试,做了一个小结,为经常做大促页面的兄弟姐妹们提供参考解决方案. 首先来看看现象.最经典的页面如下图 从图中可以看到本页面为经典的顶部大图通栏,尺寸为1210px,但是为了兼顾所有分辨率,所以作为背景图片居中处理.内容区域为常用的经典栅格布局990px,设置margin:0 auto;大概的伪代码结构如下:  XHTML 1 2 3 4 <div id=”content”> <div

解决移动端1px边框问题的几种方法

1.边框粗细原因 在移动端下设置border为1px,在某些设备上看比1px粗. 这些由于不同的手机有不同的像素密度.在window对象中有一个devicePixelRatio属性,他可以反应css中的像素与设备的像素比. devicePixelRatio的官方的定义为:设备物理像素和设备独立像素的比例,也就是 devicePixelRatio = 物理像素 / 独立像素. 2.解决办法 a.使用border-image实现 根据需求选择图片,然后根据css的border-image属性设置.代

移动端1px解决方法

前端的同学想必都碰到过1px边框的问题,在高分屏手机上,我们会发现自己写的1px往往会比预想的“粗”一些,下面是他人总结的解决方案. 单线 写一个高度为1px的线,然后通过transform:scaleY(0.5)缩放来实现 1 div{ 2 height:1px; 3 background:#ddd; 4 -webkit-transform: scaleY(0.5); 5 -webkit-transform-origin:0 0; 6 overflow: hidden; 7 } 边框+圆角 和

Linux中判断大小端的一种方法

大小端的定义无需赘言,常用的方法有使用联合体和指针法,如: int checkCPU() { union w { int a; char b; }c; c.a = 1; return (c.b == 1); // 小端返回TRUE,大端返回FALSE } 实际上Linux操作系统的源码中,其判断更为简洁: static union { char c[4]; unsigned long mylong; } endian_test = {{ 'l', '?', '?', 'b' } }; #defi

处理移动端自适应布局的方法- calc()与vw

在处理移动端自适应布局时,目前前端最流行的方法应该就是使用媒体查询,来设置HTML的字体大小,然后用rem为单位对Dom的宽高进行设置,这个方法的优势在于兼容性方面很好,劣势则在于当前市场上不同的机型太多,尺寸种类比较杂,所以要想做到所以尺寸机型都能适应,工作量相对比较大.目前也有人会选择用百分比进行布局,这个布局方法在仅仅处理元素的宽高上面非常好用,但是当js中要对dom元素的尺寸进行设置时,百分比的局限性就出来了,还有就是dom元素的font-size没办法用页面宽度百分比对他进行大小设置,