草庐IT

Vue 移动端、PC 端适配

安之若素づ 2023-08-16 原文

        Vue 移动端、PC 端适配可以使用 lib-flexible、amfe-flexible、postcss-pxtorempostcss-px2rem 和 postcss-px-to-viewport 这几个插件

        lib-flexible 是淘宝手机前端开发团队开发出来的一个开源插件,会自动在 html 的 head 中添加一个 <meta name='viewport'> 的标签,同时会自动设置 html 的 font-size 为屏幕宽度除以10。

        amfe-flexible 是 lib-flexible 的升级版本,使用 vw 作为布局单位,从底层根本上解决了不同尺寸屏幕的适配问题,因为每个屏幕的百分比是固定的、可预测、可控制的。

        postcss-pxtorem 和 postcss-px2rem 插件,用于将 px 单位转化为 rem。可以和 lib-flexible 搭配使用。

        postcss-px-to-viewport 插件用于将 px 单位转化为 vw, vh, vmin, vmax 单位。可以和 amfe-flexible 搭配使用。

移动端

方案1:lib-flexible & postcss-pxtorem

        1. 安装依赖 lib-flexible:

npm install lib-flexible --save

        2. 在 main.js 中导入依赖:

import 'lib-flexible/flexible'

        3、安装依赖 postcss-pxtorem:

npm install postcss-pxtorem@5.0.0 --save-dev

        4、配置 postcss-pxtorem:

        vue-cli2:在根目录中的 postcss.config.js (没有新建即可),添加如下代码:

module.exports = {
    plugins: {
    "postcss-pxtorem": {
      rootValue: 37.5, // lib-flexible 将屏幕分成10份(10rem),这里设置表示设计图宽度为10*37.5=375px
      unitPrecision: 5, // 保留rem小数点多少位
      propList: ['*', '!border'], // 存储将被转换的属性列表,'!font-size' 即不对字体进行rem转换
      selectorBlackList: ['.radius'], // 要忽略并保留为px的选择器,例如fs-xl类名,里面有关px的样式将不被转换,支持正则写法。
      replace: true,
      mediaQuery: false, //(布尔值)媒体查询( @media screen 之类的)中不生效
      minPixelValue: 4, // 设置要替换的最小像素值,px小于4的不会被转换
      exclude: /(node_module)/,  //默认false,可以(reg)利用正则表达式排除某些文件夹的方法,例如/(node_module)/ 。如果想把前端UI框架内的px也转换成rem,请把此属性设为默认值
    }
  }
}

        vue-cli3:在根目录中 vue.config.js (没有新建即可),添加如下代码:

module.exports = {
  css: {
    loaderOptions: {
      postcss: {
        plugins: [
          require('postcss-pxtorem')({
            rootValue: 37.5, // lib-flexible 将屏幕分成10份(10rem),这里设置表示设计图宽度为10*37.5=375px
            unitPrecision: 5,  // 保留rem小数点多少位
            propList: ['*', '!border'], // 存储将被转换的属性列表,'!font-size' 即不对字体进行rem转换
            selectorBlackList: ['.radius'], // 要忽略并保留为px的选择器,例如fs-xl类名,里面有关px的样式将不被转换,支持正则写法。
            replace: true,
            mediaQuery: false, //(布尔值)媒体查询( @media screen 之类的)中不生效
            minPixelValue: 4, // 设置要替换的最小像素值,px小于4的不会被转换
            exclude: /(node_module)/,  //默认false,可以(reg)利用正则表达式排除某些文件夹的方法,例如/(node_module)/ 。如果想把前端UI框架内的px也转换成rem,请把此属性设为默认值
          })
        ]
      }
    }
  }
}

        5、注意事项

  • 配置完成后注意删除掉 index.html 里的视窗 meta 标签 <meta name='viewport'> 以便让 lib-flexible 插件帮你生成;
  • 如果某些 px 尺寸不想转换成 rem ,将 px大写即可。
    .box{
    	width:200Px;
    	height:200PX;
    }

方案2:lib-flexible & postcss-px2rem

        1. 安装依赖 lib-flexible:

npm install lib-flexible --save

        2. 在 main.js 中导入依赖:

import 'lib-flexible/flexible'

        3、安装依赖 postcss-px2rem:

npm install postcss-px2rem --save-dev

        4、配置 postcss-px2rem:

        vue-cli2:在根目录中的 postcss.config.js (没有新建即可),添加如下代码:

module.exports = {
  plugins: {
    "postcss-px2rem": {
      remUnit: 37.5  //lib-flexible 将屏幕分成10份(10rem),这里设置表示设计图宽度为10*37.5=375px
    }
  }
}

        vue-cli3:在根目录中的 vue.config.js (没有新建即可),添加如下代码:

module.exports = {
  css: {
    loaderOptions: {
      postcss: {
        plugins: [
          require('postcss-px2rem')({
            remUnit: 37.5  //lib-flexible 将屏幕分成10份(10rem),这里设置表示设计图宽度为10*37.5=375px
          })
        ]
      }
    }
  }
}

        5、注意事项

  • 配置完成后注意删除掉 index.html 里的视窗 meta 标签 <meta name='viewport'> 以便让 lib-flexible 插件帮你生成;
  • 如果某些 px 尺寸不想转换成 rem ,将 px大写即可。
    .box{
    	width:200Px;
    	height:200PX;
    }

方案3 (推荐):amfe-flexible & postcss-px-to-viewport

        1、安装依赖 amfe-flexible:

npm install amfe-flexible --save

        2、在 main.js 中导入依赖:

import "amfe-flexible/index"

        3、安装依赖 postcss-px-to-viewport:

npm install postcss-px-to-viewport --save-dev

        4、配置  postcss-px-to-viewport:

         vue-cli2:在根目录中的 postcss.config.js (没有新建即可),添加如下代码:

module.exports = {
  plugins: {
    'postcss-px-to-viewport': {
      unitToConvert: 'px',   // 需要转换的单位
      viewportWidth: 750,    // 视口宽度,等同于设计稿宽度
      unitPrecision: 5,      // 精确到小数点后几位
      /**
      * 将会被转换的css属性列表,
      * 设置为 * 表示全部,如:['*']
      * 在属性的前面或后面设置*,如:['*position*'],*position* 表示所有包含 position 的属性,如 background-position-y
      * 设置为 !xx 表示不匹配xx的那些属性,如:['!letter-spacing'] 表示除了letter-spacing 属性之外的其他属性
      * 还可以同时使用 ! 和 * ,如['!font*'] 表示除了font-size、 font-weight ...这些之外属性之外的其他属性名头部是‘font’的属性
      * */
      propList: ['*'],
      viewportUnit: 'vw',    // 需要转换成为的单位
      fontViewportUnit: 'vw',// 需要转换称为的字体单位
      /**
      * 需要忽略的选择器,即这些选择器对应的属性值不做单位转换
      * 设置为字符串,转换器在做转换时会忽略那些选择器中包含该字符串的选择器,如:['body']会匹配到 .body-class,也就意味着.body-class对应的样式设置不会被转换
      * 设置为正则表达式,在做转换前会先校验选择器是否匹配该正则,如果匹配,则不进行转换,如[/^body$/]会匹配到 body 但是不会匹配到 .body
      */
      selectorBlackList: [],
      minPixelValue: 1,      // 最小的像素单位值
      mediaQuery: false,     // 是否转换媒体查询中设置的属性值
      replace: true,         // 替换包含vw的规则,而不是添加回退
      /**
      * 忽略一些文件,如'node_modules'
      * 设置为正则表达式,将会忽略匹配该正则的所有文件
      * 如果设置为数组,那么该数组内的元素都必须是正则表达式
      */
      exclude: [],
      landscape: false,      // 是否自动加入 @media (orientation: landscape),其中的属性值是通过横屏宽度来转换的
      landscapeUnit: 'vw',   // 横屏单位
      landscapeWidth: 1334   // 横屏宽度
    }
  }
}

        vue-cli3:在根目录中的 vue.config.js (没有新建即可),添加如下代码:

module.exports = {
  css: {
    loaderOptions: {
      postcss: {
        plugins: [
          require('postcss-px-to-viewport')({
            unitToConvert: 'px',   // 需要转换的单位
            viewportWidth: 750,    // 视口宽度,等同于设计稿宽度
            unitPrecision: 5,      // 精确到小数点后几位
            /**
            * 将会被转换的css属性列表,
            * 设置为 * 表示全部,如:['*']
            * 在属性的前面或后面设置*,如:['*position*'],*position* 表示所有包含 position 的属性,如 background-position-y
            * 设置为 !xx 表示不匹配xx的那些属性,如:['!letter-spacing'] 表示除了letter-spacing 属性之外的其他属性
            * 还可以同时使用 ! 和 * ,如['!font*'] 表示除了font-size、 font-weight ...这些之外属性之外的其他属性名头部是‘font’的属性
            * */
            propList: ['*'],
            viewportUnit: 'vw',    // 需要转换成为的单位
            fontViewportUnit: 'vw',// 需要转换称为的字体单位
            /**
            * 需要忽略的选择器,即这些选择器对应的属性值不做单位转换
            * 设置为字符串,转换器在做转换时会忽略那些选择器中包含该字符串的选择器,如:['body']会匹配到 .body-class,也就意味着.body-class对应的样式设置不会被转换
            * 设置为正则表达式,在做转换前会先校验选择器是否匹配该正则,如果匹配,则不进行转换,如[/^body$/]会匹配到 body 但是不会匹配到 .body
            */
            selectorBlackList: [],
            minPixelValue: 1,      // 最小的像素单位值
            mediaQuery: false,     // 是否转换媒体查询中设置的属性值
            replace: true,         // 替换包含vw的规则,而不是添加回退
            /**
            * 忽略一些文件,如'node_modules'
            * 设置为正则表达式,将会忽略匹配该正则的所有文件
            * 如果设置为数组,那么该数组内的元素都必须是正则表达式
            */
            exclude: [],
            landscape: false,      // 是否自动加入 @media (orientation: landscape),其中的属性值是通过横屏宽度来转换的
            landscapeUnit: 'vw',   // 横屏单位
            landscapeWidth: 1334   // 横屏宽度
          })
        ]
      }
    }
  }
}

 PC 端适配

       适配方法同移动端,但如果使用的是方案1和方案2,需要修改 lib-flexible 包中的 flexible.js 代码,注释掉如下的判断条件代码,让其在宽度大于540像素也适用。

function refreshRem(){
  var width = docEl.getBoundingClientRect().width;
  // if (width / dpr > 540) {
  //     width = 540 * dpr;
  // }
  var rem = width / 10;
  docEl.style.fontSize = rem + 'px';
  flexible.rem = win.rem = rem;
}

        如果需要在屏幕窗口变动时能无延迟适配窗口,可以修改 lib-flexible 包中的 flexible.js 代码:

win.addEventListener('resize', function() {
    clearTimeout(tid);
    tid = setTimeout(refreshRem, 0);
}, false);
win.addEventListener('pageshow', function(e) {
    if (e.persisted) {
        clearTimeout(tid);
        tid = setTimeout(refreshRem, 0);
    }
}, false);

有关Vue 移动端、PC 端适配的更多相关文章

  1. ruby - 在 Ruby 程序执行时阻止 Windows 7 PC 进入休眠状态 - 2

    我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0

  2. ruby - 多次弹出/移动 ruby​​ 数组 - 2

    我的代码目前看起来像这样numbers=[1,2,3,4,5]defpop_threepop=[]3.times{pop有没有办法在一行中完成pop_three方法中的内容?我基本上想做类似numbers.slice(0,3)的事情,但要删除切片中的数组项。嗯...嗯,我想我刚刚意识到我可以试试slice! 最佳答案 是numbers.pop(3)或者numbers.shift(3)如果你想要另一边。 关于ruby-多次弹出/移动ruby​​数组,我们在StackOverflow上找到一

  3. ruby-on-rails - 如何重命名或移动 Rails 的 README_FOR_APP - 2

    当我在我的Rails应用程序根目录中运行rakedoc:app时,API文档是使用/doc/README_FOR_APP作为主页生成的。我想向该文件添加.rdoc扩展名,以便它在GitHub上正确呈现。更好的是,我想将它移动到应用程序根目录(/README.rdoc)。有没有办法通过修改包含的rake/rdoctask任务在我的Rakefile中执行此操作?是否有某个地方可以查找可以修改的主页文件的名称?还是我必须编写一个新的Rake任务?额外的问题:Rails应用程序的两个单独文件/README和/doc/README_FOR_APP背后的逻辑是什么?为什么不只有一个?

  4. ruby-on-rails - rbenv:从 RVM 移动到 rbenv 后,在 Jenkins 执行 shell 中找不到命令 - 2

    我从Ubuntu服务器上的RVM转移到rbenv。当我使用RVM时,使用bundle没有问题。转移到rbenv后,我在Jenkins的执行shell中收到“找不到命令”错误。我内爆并删除了RVM,并从~/.bashrc'中删除了所有与RVM相关的行。使用后我仍然收到此错误:rvmimploderm~/.rvm-rfrm~/.rvmrcgeminstallbundlerecho'exportPATH="$HOME/.rbenv/bin:$PATH"'>>~/.bashrcecho'eval"$(rbenvinit-)"'>>~/.bashrc.~/.bashrcrbenvversions

  5. 计算机毕业设计ssm+vue基本微信小程序的小学生兴趣延时班预约小程序 - 2

    项目介绍随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱小学生兴趣延时班预约小程序的设计与开发被用户普遍使用,为方便用户能够可以随时进行小学生兴趣延时班预约小程序的设计与开发的数据信息管理,特开发了小程序的设计与开发的管理系统。小学生兴趣延时班预约小程序的设计与开发的开发利用现有的成熟技术参考,以源代码为模板,分析功能调整与小学生兴趣延时班预约小程序的设计与开发的实际需求相结合,讨论了小学生兴趣延时班预约小程序的设计与开发的使用。开发环境开发说明:前端使用微信微信小程序开发工具:后端使用ssm:VU

  6. (附源码)vue3.0+.NET6实现聊天室(实时聊天SignalR) - 2

    参考文章搭建文章gitte源码在线体验可以注册两个号来测试演示图:一.整体介绍  介绍SignalR一种通讯模型Hub(中心模型,或者叫集线器模型),调用这个模型写好的方法,去发送消息。  内容有:    ①:Hub模型的方法介绍    ②:服务器端代码介绍    ③:前端vue3安装并调用后端方法    ④:聊天室样例整体流程:1、进入网站->调用连接SignalR的方法2、与好友发送消息->调用SignalR的自定义方法 前端通过,signalR内置方法.invoke()  去请求接口3、监听接受方法(渲染消息)通过new signalR.HubConnectionBuilder().on

  7. ruby-on-rails - 我应该使用哪个适用于 Ruby 的 CouchDB 适配器? - 2

    一些我找到的选项是ActiveCouchCouchRESTCouchPotatoRelaxDBcouch_foo我更喜欢GitHub上的项目,因为这让我更容易fork和推送修复。所有这些都符合该要求。我习惯了Rails,所以我喜欢像ActiveRecord模型一样工作的东西。另一方面,我也不希望我和Couch之间太多--毕竟我使用它作为我的数据库是有原因的。最后,它们似乎都得到了相当积极的维护(couch_foo可能是个异常(exception))。所以我想这归结为(不可否认和不幸的)主观:有没有人对他们有过好的或坏的经历? 最佳答案

  8. ruby-on-rails - 具有六边形架构和 DCI 模式的框架和数据库适配器 - 2

    我尝试用Ruby设计一个基于Web的应用程序。我开发了一个简单的核心应用程序,在没有框架和数据库的情况下在六边形架构中实现DCI范例。核心六边形中有小六边形和网络,数据库,日志等适配器。每个六边形都在没有数据库和框架的情况下自行运行。在这种方法中,我如何提供与数据库模型和实体类的关系作为独立于数据库的关系。我想在将来将框架从Rails更改为Sinatra或数据库。事实上,我如何在这个核心Hexagon中实现完全隔离的rails和mongodb的数据库适配器或框架适配器。有什么想法吗? 最佳答案 ROM呢?(Ruby对象映射器)。还有

  9. ruby - 在 ruby​​ Selenium 中移动鼠标(move_to) - 2

    我正在尝试使用Ruby中的SeleniumWebDriver2.4模拟鼠标移动如果我运行测试,是否应该看到鼠标在我的屏幕上移动?我很困惑。我试过很多不同的方法示例代码:require'selenium-webdriver'driver=Selenium::WebDriver.for:firefoxdriver.navigate.to'http://www.google.com'element=driver.find_element(:id,'gbqfba')那我试过了driver.action.move_to(element).performdriver.mouse.move_to(e

  10. ruby-on-rails - 使用 PostgreSQL 适配器限制 ActiveRecord 迁移 5.0 中的文本列 - 2

    我的迁移看起来像这样classCreateQuestionings现在,当我运行$rakedb:migrate:reset时,在我的db/schema.rb中看不到限制:create_table"questionings",force::cascadedo|t|t.text"body",null:falseend我做错了吗还是这是一个错误?顺便说一下,我使用的是rails5.0.0.beta3和ruby​​2.3.0p0。 最佳答案 t.text在PostgreSQL和textdoesn'tallowforsizelimits中生成

随机推荐