返回顶部
首页 > 资讯 > 精选 >如何解决移动端Html5页面中1px边框的问题
  • 784
分享到

如何解决移动端Html5页面中1px边框的问题

2023-06-09 14:06:35 784人浏览 八月长安
摘要

这篇文章将为大家详细讲解有关如何解决移动端HTML5页面中1px边框的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。问题提出这是一个比较老的问题了,我第一次注意到的时候,是UI设计师来找我麻烦,emm

这篇文章将为大家详细讲解有关如何解决移动端HTML5页面中1px边框的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

问题提出

这是一个比较老的问题了,我第一次注意到的时候,是UI设计师来找我麻烦,emmm那时候我才初入前端职场,啥也不懂啊啊啊啊啊,情形是这样的:

设计师拿着手机过来:这些边框都粗了啊,我的设计稿上是1px的

我:????我写的是1px呀,不信你看。(说着拿出了CSS代码

设计师:不对啊我眼睛看来这个边框比我设计稿上粗很多,看起来好奇怪(emmm果然像素眼

我:那我把它改成0.5px你看看(边说边改了代码

设计师一看,点点头,果然好很多。

后来发现同样的代码在某些安卓机上是有问题的,会导致0.5px的线看不见。

奇了怪了,显然改成0.5px不能解决问题,但是确实1px边框看上去比设计稿上要粗很多,原因何在?

1px边框的表现

我直接使用css去定1px的边框,

html:

<ul class="hairlines">  <li>1</li>  <li>2</li></ul>

css:

* {      margin: 0;      padding: 0;    }    ul, li{      list-style: none;    }    .hairlines {      width: 300px;      margin: 100px auto;    }    .hairlines li{      position: relative;      margin-top: 10px;      border-bottom: 1px solid #cccccc; // 边框设置成1px    }

得到的截图如下:

如何解决移动端Html5页面中1px边框的问题

看上去是比设计稿上要粗很多,设计稿上的应该是下面这样的,大家可以比对一下:

如何解决移动端Html5页面中1px边框的问题

解决方法一:伪类+transform

抱着解决问题的心理,虽然当时也没有想清楚原因在哪,但是还是找到了相关的解决方法,其中一些方法中提到使用边框图片border-image或者box-shadow,也可以模拟出想要的1px边框效果,但是我个人觉得不通用,也不是常规解决方法。

最终选择的是使用伪类+transfORM方法:原理是把原先元素的 border 去掉,然后利用 :before 或者 :after 重做 border ,并 transform 的 scale 缩小一半,原先的元素相对定位,新做的 border 绝对定位。

html同上

css如下:

* {      margin: 0;      padding: 0;    }    ul, li{      list-style: none;    }    .hairlines {      width: 300px;      margin: 100px auto;    }    .hairlines li{      position: relative;      border:none;      margin-top: 10px;    }    .hairlines li:after{      content: '';      position: absolute;      left: 0;      bottom: 0;      background: #cccccc;      width: 100%;      height: 1px;      -WEBkit-transform: scaleY(0.5);      transform: scaleY(0.5);      -webkit-transform-origin: 0 0;      transform-origin: 0 0;    }

这样的话,画出的线确实细很多,我在之后长达一年的时间里面一般都是使用上面的方法去解决1px边框的问题,但用着用着,我发现了几个问题:

为什么是scaleY(0.5)?这个0.5是怎么得出的?是不是所有机型都是要scale缩小到一半,换句话说是不是通用?

如果我要同时画一个容器的四个边框怎么办?

支不支持圆角边框?

后两个问题改造一下上面的代码,可以找到解决方法(为了方便查看效果,我把平时写法得出的效果和使用伪类得出的效果放一起,这样更容易看出差别):

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <meta name="viewport" content="initial-scale=1, maximum-scale=1, minimum-scale=1, user-Scalable=no, width=device-width">  <title>移动端1px边框问题</title>  <style>    * {      margin: 0;      padding: 0;    }    ul, li{      list-style: none;    }    .lines {      width: 200px;      margin: 0 auto;    }    .lines li {      border: 1px solid #cccccc;      height: 50px;      line-height: 50px;      text-align: center;      border-radius: 13px;      margin-top: 10px;    }    .hairlines {      width: 200px;      margin: 0 auto;      border-radius: 3px;    }    .hairlines li{      height: 50px;      line-height: 50px;      border:none;      text-align: center;      position: relative;      margin-top: 10px;    }    .hairlines li:after{      content: '';      position: absolute;      left: 0;      top: 0;      border: 1px solid #cccccc;      border-radius: 26px;      width: 200%;      height: 200%;      -webkit-transform: scale(0.5);      transform: scale(0.5);      -webkit-transform-origin: left top;      transform-origin: left top;    }  </style></head><body>粗线<ul class="lines">  <li>1</li>  <li>2</li></ul>细线<ul class="hairlines">  <li>3</li>  <li>4</li></ul></body></html>

这样得出的效果图如下:

如何解决移动端Html5页面中1px边框的问题

下面的边框明显细很多,更贴近于设计稿。

那么“1.为什么是scaleY(0.5)?这个0.5是怎么得出的?是不是所有机型都是要scale缩小到一半,换句话说是不是通用?”这个问题该怎么回答呢?

这就要回到问题的本质,为什么我明明在css里面写了1px,但是仍然会出现“看起来比平时要粗很多的效果”?

查了资料看了下,原来css中设置的像素并不是跟设备的像素点一一对应,这就是说,我在css中写明1px,实际在手机上,看到的有可能并不是一个像素点占据的宽度。

css的像素是一个抽象的相对的概念,在不同的设备和环境中,所表示的物理像素点是不一样的,在比较老的设备上,屏幕像素密度比较低,这样,确实一个1px的像素就是一个物理像素,但是技术飞速发展,现在的手机屏幕都是高分辨率,在尺寸未变化的情况下,一个屏幕上将充满着更多的像素点,这时一个css的像素(通常称为逻辑像素)将对应多个物理像素点。

那到底一个css的像素宽度上对应多少个物理像素点呢?

这就要提到devicePixelRatio(设备像素比)

devicePixelRatio = 设备上物理像素/独立像素,可以通过window.devicePixelRatio获取,这个像素比恰好可以描述一个css的像素宽度上对应多少个物理像素点,其实就是对应devicePixelRatio个像素点。

当viewport的属性initial-scale为1时,页面大小正常,但initial-scale为0.5时,页面被缩小了1倍,devicePixelRatio为2的设备本来1个CSS像素宽度占2个物理像素宽度,缩小后的1个CSS像素宽度就只占1个物理像素,即实现了真正的1物理像素。

解决方法二:rem + viewport

说到这里,解决方法就很明了了:我们可以在运行的时候拿到设备的devicePixelRatio,动态改变viewport的initial-scale为 1/devicePixelRatio,这样就能保证1px的宽度就是真正的1物理像素宽。其他适配使用rem(因为使用px的话都会被缩小)

代码如下:

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <!--<meta name="viewport" content="initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no, width=device-width">-->  <title>移动端1px边框问题</title>  <script>    (function () {      var clientWidth = window.screen.width;      var dpr = window.devicePixelRatio;      var vp = document.createElement('meta');      document.documentElement.style.fontSize = clientWidth > 414 ? '20px' : 20 * dpr * clientWidth / 360 + 'px';      vp.name = 'viewport';      vp.content = `initial-scale=${1.0 * 1 / dpr}, maximum-scale=${1.0 * 1 / dpr}, minimum-scale=${1.0 * 1 / dpr}, user-scalable=no, width=device-width`;      var m = document.getElementsByTagName('meta')[0];      m.parentnode.insertBefore(vp, m);    })();  </script>  <style>    * {      margin: 0;      padding: 0;    }    ul, li{      list-style: none;    }    .lines {      width: 10rem;      margin: 0 auto;    }    .lines li {      border: 1px solid #cccccc;      height: 2.5rem;      line-height: 2.5rem;      text-align: center;      border-radius: 0.6rem;      margin-top: 0.5rem;    }  </style></head><body><ul class="lines">  <li>1</li>  <li>2</li></ul></body></html>

得到的效果可以看下图(手机上看更明显一些):

如何解决移动端Html5页面中1px边框的问题

从上来看,回到之前的问题,"1.为什么是scaleY(0.5)?这个0.5是怎么得出的?是不是所有机型都是要scale缩小到一半,换句话说是不是通用?"其实并不一定是0.5,在dpr为3的设备上其实应该是0.3333&hellip;&hellip;,也不通用,因为每个手机的dpr可能不一样,但是方法一中的0.5一般因为至少比1px细,所以也差不多可以满足设计师的要求了。

关于“如何解决移动端Html5页面中1px边框的问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: 如何解决移动端Html5页面中1px边框的问题

本文链接: https://lsjlt.com/news/256262.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何解决移动端Html5页面中1px边框的问题
    这篇文章将为大家详细讲解有关如何解决移动端Html5页面中1px边框的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。问题提出这是一个比较老的问题了,我第一次注意到的时候,是UI设计师来找我麻烦,emm...
    99+
    2023-06-09
  • 如何解决移动端1px边框的问题
    这篇文章主要为大家展示了“如何解决移动端1px边框的问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决移动端1px边框的问题”这篇文章吧。当然了,在这之...
    99+
    2024-04-02
  • 如何解决移动端1px边框
    这篇文章主要介绍了如何解决移动端1px边框,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在移动端开发时,经常会遇到在视网膜屏幕中元素边框变粗的问题。1px 边框问题的由来苹果...
    99+
    2023-06-08
  • 如何实现移动端HTML5页面去掉input输入框的白色背景和边框
    这篇文章主要介绍如何实现移动端HTML5页面去掉input输入框的白色背景和边框,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!效果:jsp 部分代码:<div> ...
    99+
    2024-04-02
  • 如何解决HTML5手机端页面缩放的问题
    小编给大家分享一下如何解决HTML5手机端页面缩放的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!通常在写HTML5手机端页...
    99+
    2024-04-02
  • 如何解决html5在移动端的屏幕适应问题
    这篇文章主要讲解了“如何解决html5在移动端的屏幕适应问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何解决html5在移动端的屏幕适应问题”吧! ...
    99+
    2024-04-02
  • 如何解决移动端HTML5音频与视频的问题
    小编给大家分享一下如何解决移动端HTML5音频与视频的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!最近在研究用视频代替动画,用视频代替精灵动画,我们称这种视...
    99+
    2023-06-09
  • web开发中如何解决移动端设置了overflow:hidden页面还会滚动的问题
    这篇文章主要为大家展示了“web开发中如何解决移动端设置了overflow:hidden页面还会滚动的问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“web开...
    99+
    2024-04-02
  • PyQt5项目中无边框后窗口出现移动问题如何解决
    这篇文章将为大家详细讲解有关PyQt5项目中无边框后窗口出现移动问题如何解决,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。判断鼠标左键是否被按下,如果按下则将flag设为True并获取当前的...
    99+
    2023-06-08
  • 如何解决移动端html5页面长按实现高亮全选文本内容的兼容问题
    这篇文章主要介绍如何解决移动端html5页面长按实现高亮全选文本内容的兼容问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!最近需要给HTML5的WebAPP在页面上实现一个复制功能...
    99+
    2024-04-02
  • 如何解决移动端吸顶fixbar的问题
    这篇文章主要介绍如何解决移动端吸顶fixbar的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!需求背景经常会有这样的需求,当页面滚动到某一个位置时,需要某个页面元素固定在屏幕顶部...
    99+
    2024-04-02
  • css3如何解决移动端卡顿的问题
    这篇文章主要介绍css3如何解决移动端卡顿的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、使用css,jquery,canvas制作动画Canvas优点:性能好,强大,支持多数浏览器(除了IE6、IE7、IE...
    99+
    2023-06-08
  • 如何解决HTML5页面在iPhoneX适配问题
    这篇文章将为大家详细讲解有关如何解决HTML5页面在iPhoneX适配问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1.  iPhoneX的介绍 ...
    99+
    2024-04-02
  • 如何解决PC端和移动端自适应问题
    这篇文章主要介绍了如何解决PC端和移动端自适应问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。做网页时,我们通常需要考虑到不同电脑屏幕尺寸,以及不同手机屏幕大小等问题,解决...
    99+
    2023-06-08
  • vue如何解决移动端弹出键盘导致页面fixed布局错乱的问题
    这篇文章将为大家详细讲解有关vue如何解决移动端弹出键盘导致页面fixed布局错乱的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。问题图片这里确认按钮是fixed布局...
    99+
    2024-04-02
  • 如何解决移动端小图标模糊的问题
    这篇文章将为大家详细讲解有关如何解决移动端小图标模糊的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言之前给大家讲到图片和文字垂直方向不对齐的问题,其中举的小例子中用到了一个小图标,这个小图标我用的...
    99+
    2023-06-08
  • 如何解决canvas在移动端绘制模糊的问题
    小编给大家分享一下如何解决canvas在移动端绘制模糊的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!由于一些移动端的兼容性原因,我们某个项目需要前端将pdf...
    99+
    2023-06-09
  • 如何解决html5手机端页面可以向右滑动导致样式受影响的问题
    这篇文章主要介绍如何解决html5手机端页面可以向右滑动导致样式受影响的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!问题描述发现写的h6页面在手机端可以向右滑动,导致样式出现问...
    99+
    2024-04-02
  • 如何解决webapp页面滚动卡顿问题
    本篇文章给大家分享的是有关如何解决webapp页面滚动卡顿问题,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。addEventListener的useCapture参数基本概念:...
    99+
    2023-06-09
  • css如何使用:not() 解决lists边框的问题
    小编给大家分享一下css如何使用:not() 解决lists边框的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!使用:not() 解决lists边框的问题在w...
    99+
    2023-06-27
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作