位置: IT常识 - 正文

Vue3、vite项目页面自适应配置(postcss-plugin-px2rem、amfe-flexible)(vue项目页面写在哪里)

编辑:rootadmin
Vue3、vite项目页面自适应配置(postcss-plugin-px2rem、amfe-flexible)

推荐整理分享Vue3、vite项目页面自适应配置(postcss-plugin-px2rem、amfe-flexible)(vue项目页面写在哪里),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue3.0项目,vue项目搭建好之后如何写页面,vue项目搭建好之后如何写页面,vue项目前端页面模板,vue3项目目录,vue项目搭建好之后如何写页面,vue3.0项目,vue项目搭建好之后如何写页面,内容如对您有帮助,希望把文章链接给更多的朋友!

文章目录前言:vite 如何处理 csspostcss项目配置下载相关包配置方案一方案二(备选方案)相关资料链接前言:vite 如何处理 css

vite 天生就支持对css文件的直接处理 关于预处理器

☀️目前,在工程化开发中,使用最多的应该就是Less、Sass和Stylus。 ☀️首先,还是介绍一下它们吧。它们有个统一的名字——css预处理器。 ☀️何为CSS预处理器?应该就是一种可以将你根据它的规则写出来的格式转成css的东西(还是讲的通 俗一点)。 ☀️它们的出现可以说是恰逢其时,解决了css的一些缺憾: 1、语法不够强大,不能够嵌套书写,不利于模块化开发 2、没有变量和逻辑上的复用机制,导致在css的属性值中只能使用字面量形式,以及不断重复书写重复 3、的样式,导致难以维护。

postcss

☀️vite 天生对postcss有非常好的支持 ☀️postcss => 保证css在执行起来是万无一失的 ☀️你可以在使用预处理器的情况下使用它,也可以在原生的css中使用它。 ☀️它都是支持的,并且它具备着一个庞大的生态系统,例如你可能常用的Autoprefixer,就是PostCSS ☀️的一个非常受欢迎的插件,被Google, Shopify, Twitter, Bootstrap和CodePen等公司广泛使用。

Vue3、vite项目页面自适应配置(postcss-plugin-px2rem、amfe-flexible)(vue项目页面写在哪里)

在这里就不用多说,后续会出单独一篇来讲这个东西,postcss是一个十分强大的工具

项目配置下载相关包npm install amfe-flexible -snpm i postcss-plugin-px2rem -s配置方案一

vite.config.js的关于这个的配置 没有这个文件可以在项目根目录创建这个文件,进行配置 注意:vite.config.js 配置 需要导入(看具体需要)

import { defineConfig, loadEnv} from "vite";import vue from "@vitejs/plugin-vue";

❤️ vite.config.js 部分配置

const px2remOptions = { rootValue: 14.4, //换算基数, 默认100 ,也就是1440px ,这样的话把根标签的字体规定为1rem为50px,这样就可以从设计稿上量出多少个px直接在代码中写多少px了 unitPrecision: 5, //允许REM单位增长到的十进制数字,其实就是精度控制 // propWhiteList: [], // 默认值是一个空数组,这意味着禁用白名单并启用所有属性。 // propBlackList: [], // 黑名单 // exclude:false, //默认false,可以(reg)利用正则表达式排除某些文件夹的方法,例如/(node_module)/ 。如果想把前端UI框架内的px也转换成rem,请把此属性设为默认值 // selectorBlackList: [], //要忽略并保留为px的选择器 // ignoreIdentifier: false, //(boolean/string)忽略单个属性的方法,启用ignoreidentifier后,replace将自动设置为true。 // replace: true, // (布尔值)替换包含REM的规则,而不是添加回退。 mediaQuery: false, //(布尔值)允许在媒体查询中转换px minPixelValue: 0 //设置要替换的最小像素值(3px会被转rem)。 默认 0}return defineConfig({ resolve: { alias: [{ find: '@', replacement: path.resolve(__dirname, './src') }] }, plugins: [vue()], base: process.env.VITE_APP_BASE, build: { outDir: 'dist', }, css: { postcss: { plugins: [px2rem(px2remOptions)] } } });

❤️ 我们剩下的就是动态修改html的font-size 创建utils/dom.js文件

import _ from 'lodash'// 以1920px 底图为准开发页面export const setDomFontSize = () => { let width = document.documentElement.clientWidth || document.body.clientWidth; let fontsize = (width <= 200 ? 1200 : width) / 100 + 'px'; (document.getElementsByTagName('html')[0].style)['font-size'] = fontsize;}let setDomFontSizeDebounce = _.debounce(setDomFontSize, 400)window.addEventListener('resize', setDomFontSizeDebounce); // 浏览器加入收缩监听防抖,重新计算rem配置

剩下的就是在main.js 里面引入并触发函数

import { setDomFontSize} from './utils/dom'setDomFontSize()

其实我们上面的方案的配置也可以写在单独的文件里

方案二(备选方案)

postcss.config.js 如果没有该文件就自己在项目根目录上创建postcss.config.js

module.exports = { plugins: [ require("autoprefixer"), require("postcss-plugin-px2rem")({ //rootValue: 19.2, //换算基数,1rem相当于10px,值为37.5时,1rem为20px,淘宝的flex默认为1rem为10px // unitPrecision: 5, //允许REM单位增长到的十进制数字。 //propWhiteList: [], //默认值是一个空数组,这意味着禁用白名单并启用所有属性。 propBlackList: ['font-size', 'border'], //黑名单 exclude: /(node_module)/, //默认false,可以(reg)利用正则表达式排除某些文件夹的方法,例如/(node_module)\/如果想把前端UI框架内的px也转换成rem,请把此属性设为默认值 // selectorBlackList: [], //要忽略并保留为px的选择器 // ignoreIdentifier: false, //(boolean/string)忽略单个属性的方法,启用ignoreidentifier后,replace将自动设置为true。 // replace: true, // (布尔值)替换包含REM的规则,而不是添加回退。 mediaQuery: false, //(布尔值)允许在媒体查询中转换px。 minPixelValue: 3, //设置要替换的最小像素值(3px会被转rem)。 默认 0 }), ],};相关资料链接

B站教学vite教学视频 掘金好文-配置文章 掘金好文-谈谈PostCSS 深入学习postcss

本文链接地址:https://www.jiuchutong.com/zhishi/283985.html 转载请保留说明!

上一篇:Python之ImportError: DLL load failed: 找不到指定的模块解决方案

下一篇:edge浏览器被百度占用了如何解决?(edge浏览器百度网盘插件)

  • 华为智能门锁能用小米手机开吗(华为智能门锁能不能远程开锁)

    华为智能门锁能用小米手机开吗(华为智能门锁能不能远程开锁)

  • ppt页码怎么去掉(怎样去掉ppt页码)

    ppt页码怎么去掉(怎样去掉ppt页码)

  • 什么语言是用助记符代替操作码(什么语言是用助记)

    什么语言是用助记符代替操作码(什么语言是用助记)

  • 华为音响小艺怎么连接(华为音响小艺怎么更换wifi)

    华为音响小艺怎么连接(华为音响小艺怎么更换wifi)

  • 都是黄钻能互看隐身访问吗(互为黄钻能看到对方的访问记录吗)

    都是黄钻能互看隐身访问吗(互为黄钻能看到对方的访问记录吗)

  • 联系人停止运行如何解决(联系人停止运行如何恢复正常)

    联系人停止运行如何解决(联系人停止运行如何恢复正常)

  • 华为gt测心率准吗(华为gt心率区间设置)

    华为gt测心率准吗(华为gt心率区间设置)

  • vivo官网寄修啥时候付钱(vivo寄修服务流程)

    vivo官网寄修啥时候付钱(vivo寄修服务流程)

  • 如何制作抖音短视频(如何制作抖音短视频照片)

    如何制作抖音短视频(如何制作抖音短视频照片)

  • 芯片组驱动是什么(芯片组驱动程序是什么)

    芯片组驱动是什么(芯片组驱动程序是什么)

  • ppt改比例(ppt改比例后背景改变)

    ppt改比例(ppt改比例后背景改变)

  • 买了腾讯vip可以退款吗(腾讯视频的vip可以)

    买了腾讯vip可以退款吗(腾讯视频的vip可以)

  • 苹果手机出现可能不支持此配件是什么意思(苹果手机出现可能需要几分钟时间激活iphone)

    苹果手机出现可能不支持此配件是什么意思(苹果手机出现可能需要几分钟时间激活iphone)

  • 抖音的共同好友指什么(抖音的共同好友在哪里看)

    抖音的共同好友指什么(抖音的共同好友在哪里看)

  • 手机没话费了怎么办(手机没话费了怎么能收到短信)

    手机没话费了怎么办(手机没话费了怎么能收到短信)

  • 诺和笔使用方法(诺和笔使用说明)

    诺和笔使用方法(诺和笔使用说明)

  • bkk一al10是什么型号(bkk-al10)

    bkk一al10是什么型号(bkk-al10)

  • 手机uc隐藏空间在哪(手机uc隐藏空间在哪里)

    手机uc隐藏空间在哪(手机uc隐藏空间在哪里)

  • 华为nova5pro和nova5区别(华为nova5pro和nova5ipro有什么区别)

    华为nova5pro和nova5区别(华为nova5pro和nova5ipro有什么区别)

  • qq轻聊版如何退出账号(qq轻聊版怎样切换帐号)

    qq轻聊版如何退出账号(qq轻聊版怎样切换帐号)

  • 手机酷狗音乐怎么下载到u盘(手机酷狗音乐怎么下载到手机文件夹)

    手机酷狗音乐怎么下载到u盘(手机酷狗音乐怎么下载到手机文件夹)

  • jpg格式图片怎么打开(jpg格式图片怎么打印出来)

    jpg格式图片怎么打开(jpg格式图片怎么打印出来)

  • win11系统设置在哪?win11打开系统设置教程(win11打开设置)

    win11系统设置在哪?win11打开系统设置教程(win11打开设置)

  • mac hosts文件已锁定无法修改怎么办(mac host is down)

    mac hosts文件已锁定无法修改怎么办(mac host is down)

  • 操作系统的安全性(操作系统的安全目标主要包括哪些?)

    操作系统的安全性(操作系统的安全目标主要包括哪些?)

  • Linux怎么配置双机SSH互相信任实现免密码登录?(linux双ip路由设置方法)

    Linux怎么配置双机SSH互相信任实现免密码登录?(linux双ip路由设置方法)

  • Python一点通: ‘python -m pip install’ 和 ‘pip install‘ 什么区别?(python一点都不简单)

    Python一点通: ‘python -m pip install’ 和 ‘pip install‘ 什么区别?(python一点都不简单)

  • Python中自定义异常的使用举例(Python中自定义异常)

    Python中自定义异常的使用举例(Python中自定义异常)

  • 个体户开增值税怎么开
  • 借款利息收入是企业收入吗
  • 新个税法申报的税种
  • 金税四期影响企业贷款吗
  • 购买软件费用
  • 其他综合收益包括资本公积吗
  • 公司合作分红
  • 年终奖分摊到每个月
  • 附加税申报减免性质代码下面的三个请选择用填吗
  • 发票开票地址是注册地址还是经营地址
  • 关于年底双薪和分红问题的处理
  • 债权性投资损失账务处理
  • 销售额负数 如何填报报表
  • 营利性养老机构需要缴纳哪些税
  • 研发费用准备金计提账务处理
  • 一般纳税人交增值税会计科目
  • 去年多摊销的费用今年怎么做账务处理?
  • 长期借款产生的利息计入哪个科目
  • 农业企业土地租赁费账务处理
  • 个人独资企业可以不开公户吗
  • 个人所得税退税多久到账
  • 增值税和消费税常用的公式
  • 单位有临时工工资怎么发
  • 汇算清缴涉及到哪些科目的调整
  • 外贸企业零退税怎么算
  • 非公司车辆的使用费如何入账?
  • 购进商品用于样品赠送的账务处理
  • 存货入库后的仓储费记录
  • 投资合伙企业对公司有债务责任吗
  • 用积分兑换礼品英语怎么说
  • 电脑网页密码不正确
  • 高新技术企业所得税优惠政策最新2022
  • 微信聊天记录备份和恢复
  • 调整之前的凭证怎么删除
  • 核定征收的企业怎么交所得税
  • 免抵退税的具体计算方法
  • 水表同步
  • php 调试工具
  • 研发支出属于哪个表
  • 公司注销账面实收资本如何处理
  • framework core
  • Python 计算机视觉(八)—— OpenCV 进行图像增强
  • 达摩院 2021
  • php websocket教程
  • 企业所得税汇算清缴
  • switch关键账号教程
  • 应收账款提坏账准备的方法
  • 财务报表怎么重新编制
  • 租厂房需要去缴房产税吗
  • mysql常见错误
  • 预充值发票可以报销吗
  • 进项认证以后如何处理
  • 企业会计凭证怎么写
  • 收回投资收到的现金占比大说明
  • 预收账款的账务处理
  • 收到工程款时会计分录
  • 营改增之前广告位出租
  • 什么是雇主责任险保单
  • 外商投资企业的中国投资者
  • 存放在仓库中的原材料
  • 应收账款坏账的说明
  • 应付票据和应付债券的区别
  • 如何建立明细分类账
  • 分页存储过程的实现
  • torch.cuda.set_device
  • win10windows更新
  • win8一直在开始界面
  • xp 桌面图标
  • js修改css样式属性不生效
  • css查找元素
  • js实现登录功能
  • unity3d怎么让物体依次运动
  • js的scrolltop
  • 安卓activity和fragment的区别
  • 票据代码和票据号码是什么意思
  • 云南省国家税务局电子税务局官网
  • 2021边疆补助什么时候下来
  • 广东省电子税务局app下载官网
  • 广东广州税务局电话
  • 每月个人所得税扣除标准
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设