移动端常见适配方案

1 篇文章 0 订阅
1 篇文章 0 订阅

一丶利用CSS中 媒体查询+rem

rem是一个相对单位,1rem等于html的font-size大小
而我们可以通过媒体查询可视区域screen的大小变化,然后修改对应html的font-size大小

例如:

@media screen and (min-width:375px) {
    html {
        font-size: 37.5px;
    }
}
@media screen and (min-width:414px) {
    html {
        font-size: 41.4px;
    }
}
 
 //1rem = font-size的值
.box {
    width: 5rem;
    height: 5rem;
    background-color: pink;
}

优点:屏幕尺寸发生变化时,界面自动变化,不用手动刷新
缺点:屏幕尺寸大小不一,不可能任何尺寸的屏幕都进行一遍适配

二丶配置flexible.js动态计算

<script src="./js/flexible.js"></script>

媒体查询写起来超级麻烦,而且检测不够精确,因此我们使用 flexible.js 这个 js文件,通过js 实时检测屏幕窗口的变化实现检测视口宽度,自动修改html文字大小,这样就可以让盒子配合rem完成适配

flexible 能够修改html文字大小,修改文字大小: 当前屏幕 / 10 就是文字大小
例如: 当前屏幕 375px,则加了 flexible之后,html文字大小为 37.5px

这里我已经把flexible的源码赋值过来了,大家可以用到自己的flexible.js中

(function flexible (window, document) {
  var docEl = document.documentElement
  var dpr = window.devicePixelRatio || 1

  // adjust body font size
  function setBodyFontSize () {
    if (document.body) {
      document.body.style.fontSize = (12 * dpr) + 'px'
    }
    else {
      document.addEventListener('DOMContentLoaded', setBodyFontSize)
    }
  }
  setBodyFontSize();

  // set 1rem = viewWidth / 10
  function setRemUnit () {
    var rem = docEl.clientWidth / 10
    docEl.style.fontSize = rem + 'px'
  }

  setRemUnit()

  // reset rem unit on page resize
  window.addEventListener('resize', setRemUnit)
  window.addEventListener('pageshow', function (e) {
    if (e.persisted) {
      setRemUnit()
    }
  })

  // detect 0.5px supports
  if (dpr >= 2) {
    var fakeBody = document.createElement('body')
    var testElement = document.createElement('div')
    testElement.style.border = '.5px solid transparent'
    fakeBody.appendChild(testElement)
    docEl.appendChild(fakeBody)
    if (testElement.offsetHeight === 1) {
      docEl.classList.add('hairlines')
    }
    docEl.removeChild(fakeBody)
  }
}(window, document))

或者npm install amfe-flexible --save

px->rem工具
vscode中下载扩展:

在这里插入图片描述然后对其进行配置,开发中按照你设计时用屏幕对其设置,例如你用的是375px,则将值设置为37.5
在这里插入图片描述

或者npm install postcss-pxtorem --save
postcss-pxtorem是postcss的插件,用于将像素单元生成rem单位
配置postcss-pxtorem,可在vue.config.js、.postcssrc.js、postcss.config.js其中之一配置,权重从左到右降低,没有则新建文件,只需要设置其中一个即可:

为了方便 我是在 vue.config.js 配置的代码配置如下:

module.exports = {

    //...其他配置

    css: {

        loaderOptions: {

            postcss: {

                plugins: [

                    require('postcss-pxtorem')({

                        rootValue: 37.5,

                        propList: ['*']

                    })

                ]

            }

        }

    },

}

注意点:
1、rootValue根据设计稿宽度除以10进行设置,这边假设设计稿为375,即rootValue设为37.5;
2、propList是设置需要转换的属性,这边*为所有都进行转换

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
移动端像素适配是指在开发移动应用或网页时,使元素在不同设备上显示一致。常见移动端像素适配方案是基于CSS像素和设备独立像素的概念。 在移动设备中,设备独立像素是一个虚拟像素单位,可以认为是计算机坐标系中的一个点,它代表了程序使用的虚拟像素。而CSS像素则是网页或应用中的单位,用于定义元素的大小和位置。 对于移动设备的像素适配,一种常见的做法是将设计稿以750px的宽度作为基准进行适配。这意味着在CSS中,元素的尺寸应该按照设计稿中的尺寸进行设置,同时使用媒体查询等技术来适配不同的设备屏幕宽度。 例如,设计稿中一个元素的宽度为100px,在CSS中可以设置为: width: 100px; 但是为了适配不同设备,可以使用媒体查询来调整元素的样式,例如: @media screen and (max-width: 375px) { width: 50px; } 这样,在375px宽度以下的设备上,这个元素的宽度会变为50px,以适应不同的屏幕尺寸。 需要注意的是,移动端像素适配还需要考虑设备像素比(DPR),即设备物理像素和设备独立像素的比例关系。通常情况下,一个CSS像素对应一个设备独立像素,但在高清屏幕上,一个CSS像素可能对应多个设备物理像素。因此,在进行移动端像素适配时,还需要根据设备像素比进行相应的调整。 总结起来,移动端像素适配是通过使用CSS像素和设备独立像素的概念,结合媒体查询和设备像素比来实现元素在不同移动设备上的一致显示。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [移动端像素概念,viewport,适配](https://blog.csdn.net/dongqian911/article/details/113955011)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值