vue页面自适应 动态 postcss postcss-pxtorem

2024-08-28 05:12

本文主要是介绍vue页面自适应 动态 postcss postcss-pxtorem,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

vue页面自适应 动态 postcss postcss-pxtorem

  • postcss-pxtorem实现页面自适应
    • 1、安装postcss-pxtorem
    • 2、根目录创建postcss.config.js,并配置以下内容
    • 3、创建rem.js,动态设置root px
    • 4、在main.js中引入rem.js
    • 5、在main.js中创建全局处理函数px2rem
    • 6、对内联样式使用px2rem

背景:vue2做的页面,希望可以根据浏览器分辨率动态调整页面元素大小

postcss一款灵活配置css的插件,而postcss-pxtorem是属于postcss中的小工具可以动态将页面px转换为rem,现使用postcss-pxtorem实现页面自适应效果

postcss-pxtorem实现页面自适应

1、安装postcss-pxtorem

npm install postcss-pxtorem --s

2、根目录创建postcss.config.js,并配置以下内容

module.exports = {plugins: {"postcss-pxtorem": {rootValue: 16, // 根元素字体大小,用于将像素转换为rem的基准值unitPrecision: 5, // rem的小数位数propList: ["*"], // 需要转换的属性列表,['*']表示所有属性都会被转换。selectorBlackList: [], // 需要忽略的选择器,可以是正则表达式或字符串replace: true, // 是否替换原始值mediaQuery: false, // 是否在媒体查询中转换px。minPixelValue: 0 // 小于或等于该值的像素单位不被转换。}}
};

3、创建rem.js,动态设置root px

// 设置 rem 函数
function setRem() {// 1920 默认大小16px; 1920px = 120rem ;每个元素px基础上/16 这里是16就是初始化根元素px大小const screenWidth = 1920const scale = screenWidth / 16const htmlWidth = document.documentElement.clientWidth || document.body.clientWidth// 得到html的Dom元素const htmlDom = document.getElementsByTagName('html')[0]// 设置根元素字体大小htmlDom.style.fontSize = htmlWidth / scale + 'px'
}
// 初始化
setRem()
// 改变窗口大小时重新设置 rem
window.addEventListener('resize', ()=>{setRem()
})

4、在main.js中引入rem.js

import '@/utils/rem.js'

此时打开调试工具会发现px已经全部被转换为rem,也基本可以实现页面自适应变化了
在这里插入图片描述

注:postcss-pxtorem无法将内联样式转换为rem,此时需要额外单独处理
在这里插入图片描述

5、在main.js中创建全局处理函数px2rem

function px2rem(px){if(/%/ig.test(px)){ // 有百分号%,特殊处理,表述pc是一个有百分号的数,比如:90%return px}else{return (parseFloat(px) / 16) + 'rem' // 这里的16就是初始化根元素px大小}
}
Vue.prototype.$px2rem = px2rem // 放到全局

6、对内联样式使用px2rem

<span :style="{'margin-left': $px2rem('20px')}">内联样式</span>

到此结束,页面基本可以实现自适应!!!
若部分元素无法自适应,则可能是没有设置width、height

这篇关于vue页面自适应 动态 postcss postcss-pxtorem的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1113824

相关文章

SpringBoot全局异常拦截与自定义错误页面实现过程解读

《SpringBoot全局异常拦截与自定义错误页面实现过程解读》本文介绍了SpringBoot中全局异常拦截与自定义错误页面的实现方法,包括异常的分类、SpringBoot默认异常处理机制、全局异常拦... 目录一、引言二、Spring Boot异常处理基础2.1 异常的分类2.2 Spring Boot默

HTML5的input标签的`type`属性值详解和代码示例

《HTML5的input标签的`type`属性值详解和代码示例》HTML5的`input`标签提供了多种`type`属性值,用于创建不同类型的输入控件,满足用户输入的多样化需求,从文本输入、密码输入、... 目录一、引言二、文本类输入类型2.1 text2.2 password2.3 textarea(严格

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

SpringBoot返回文件让前端下载的几种方式

《SpringBoot返回文件让前端下载的几种方式》文章介绍了开发中文件下载的两种常见解决方案,并详细描述了通过后端进行下载的原理和步骤,包括一次性读取到内存和分块写入响应输出流两种方法,此外,还提供... 目录01 背景02 一次性读取到内存,通过响应输出流输出到前端02 将文件流通过循环写入到响应输出流

MyBatis-Plus使用动态表名分表查询的实现

《MyBatis-Plus使用动态表名分表查询的实现》本文主要介绍了MyBatis-Plus使用动态表名分表查询,主要是动态修改表名的几种常见场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录1. 引入依赖2. myBATis-plus配置3. TenantContext 类:租户上下文

Python结合Free Spire.PDF for Python实现PDF页面旋转

《Python结合FreeSpire.PDFforPython实现PDF页面旋转》在日常办公或文档处理中,我们经常会遇到PDF页面方向错误的问题,本文将分享如何用Python结合FreeSpir... 目录基础实现:单页PDF精准旋转完整代码代码解析进阶操作:覆盖多场景旋转需求1. 旋转指定角度(90/27

SpringBoot+Vue3整合SSE实现实时消息推送功能

《SpringBoot+Vue3整合SSE实现实时消息推送功能》在日常开发中,我们经常需要实现实时消息推送的功能,这篇文章将基于SpringBoot和Vue3来简单实现一个入门级的例子,下面小编就和大... 目录前言先大概介绍下SSE后端实现(SpringBoot)前端实现(vue3)1. 数据类型定义2.

使用Python实现在PDF中添加、导入、复制、移动与删除页面

《使用Python实现在PDF中添加、导入、复制、移动与删除页面》在日常办公和自动化任务中,我们经常需要对PDF文件进行页面级的编辑,使用Python,你可以轻松实现这些操作,而无需依赖AdobeAc... 目录1. 向 PDF 添加空白页2. 从另一个 PDF 导入页面3. 删除 PDF 中的页面4. 在

前端Visual Studio Code安装配置教程之下载、汉化、常用组件及基本操作

《前端VisualStudioCode安装配置教程之下载、汉化、常用组件及基本操作》VisualStudioCode是微软推出的一个强大的代码编辑器,功能强大,操作简单便捷,还有着良好的用户界面,... 目录一、Visual Studio Code下载二、汉化三、常用组件1、Auto Rename Tag2

Java中的随机数生成案例从范围字符串到动态区间应用

《Java中的随机数生成案例从范围字符串到动态区间应用》本文介绍了在Java中生成随机数的多种方法,并通过两个案例解析如何根据业务需求生成特定范围的随机数,本文通过两个实际案例详细介绍如何在java中... 目录Java中的随机数生成:从范围字符串到动态区间应用引言目录1. Java中的随机数生成基础基本随