• Vue将px转化为rem适配移动端


    Vue将px转化为rem适配移动端

    1.下载lib-flexible
    我使用的是vue-cli+webpack,所以是通过npm来安装的
    npm i lib-flexible --save

    2.引入lib-flexible
    在main.js中引入lib-flexible
    import 'lib-flexible/flexible'

    3.设置meta标签
    通过meta标签,设置设备宽度以及缩放比例
    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    4.安装px2rem-loader
    npm install px2rem-loader

    5.配置px2rem-loader
    在build文件中找到util.js,将px2rem-loader添加到cssLoaders中,如:

    const cssLoader = {
        loader: 'css-loader',
        options: {
          minimize: process.env.NODE_ENV === 'production',
          sourceMap: options.sourceMap
        }
      }
      const px2remLoader = {
        loader: 'px2rem-loader',
        options: {
          remUnit: 75
        }
      }

    同时,在generateLoaders方法中添加px2remLoader

    function generateLoaders (loader, loaderOptions) {
        const loaders = [cssLoader,px2remLoader]
        if (loader) {
          loaders.push({
            loader: loader + '-loader',
            options: Object.assign({}, loaderOptions, {
              sourceMap: options.sourceMap
            })
          })
        }
    

      

    6.重启
    当配置完之后,只需要重启下服务,就自动转化为rem了
    npm run dev

    ===============

    css中单位px和em,rem的区别
    px是固定像素,em是相对父元素字体大小的百分比,比如div设成15px,div的子节点1em就是15px,2em就是30px。
    rem和em差不多,但是是相对于html元素(文档根元素document.documentElement)而不是父元素。

    px像素(Pixel)。相对长度单位。像素px是相对于显示器屏幕分辨率而言的。
    em是相对长度单位。相对于当前对象内文本的字体尺寸。如当前对行内文本的字体尺寸未被人为设置,则相对于浏览器的默认字体尺寸。
    任意浏览器的默认字体高都是16px。所有未经调整的浏览器都符合: 1em=16px。那么12px=0.75em,10px=0.625em。为了简化font-size的换算,需要在css中的body选择器中声明Font-size=62.5%,这就使em值变为 16px*62.5%=10px, 这样12px=1.2em, 10px=1em, 也就是说只需要将你的原来的px数值除以10,然后换上em作为单位就行了。

    EM特点
    1. em的值并不是固定的;
    2. em会继承父级元素的字体大小。
    所以我们在写em的时候,需要注意两点:
    1. body选择器中声明Font-size=62.5%;
    2. 将你的原来的px数值除以10,然后换上em作为单位;
    3. 重新计算那些被放大的字体的em数值。避免字体大小的重复声明。

    rem是CSS3新增的一个相对单位(root em,根em),这个单位引起了广泛关注。
    这个单位与em有什么区别呢?区别在于使用rem为元素设定字体大小时,仍然是相对大小,但相对的只是HTML根元素。
    这个单位可谓集相对大小和绝对大小的优点于一身,通过它既可以做到只修改根元素就成比例地调整所有字体大小,又可以避免字体大小逐层复合的连锁反应。目前,除了IE8及更早版本外,所有浏览器均已支持rem。

  • 相关阅读:
    Dijksrta algorithm
    头一回发博客,来分享个有关C++类型萃取的编写技巧
    读书笔记「Python编程:从入门到实践」_4.操作列表
    读书笔记「Python编程:从入门到实践」_3.列表简介
    读书笔记「Python编程:从入门到实践」_2.变量和简单数据类型
    2017/01/20 学习笔记 关于修改和重打jar包
    2017/01/07 学习笔记 jar包,maven
    常用链接
    使用Dir,遍历文件夹下所有子文件夹及文件
    .NET WEB项目的调试发布相关
  • 原文地址:https://www.cnblogs.com/zdz8207/p/vue-px-rem-lib-flexible.html
Copyright © 2020-2023  润新知