位置: IT常识 - 正文

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

发布时间:2024-01-03
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浏览器百度网盘插件)

  • oppok9pro怎么一键锁屏(oppor9怎么一键锁屏)

    oppok9pro怎么一键锁屏(oppor9怎么一键锁屏)

  • 打印机连接线(惠普打印机连接线)

    打印机连接线(惠普打印机连接线)

  • 俩个开关控制一个灯怎么接线(俩开关控制一个灯怎么接线)

    俩个开关控制一个灯怎么接线(俩开关控制一个灯怎么接线)

  • 手机热点出现有限的访问权限(手机热点显示)

    手机热点出现有限的访问权限(手机热点显示)

  • 怎样屏蔽微信群(怎样隐藏微信群聊)

    怎样屏蔽微信群(怎样隐藏微信群聊)

  • word横排文本框怎么设置(word横排文本框怎么设置两行排列)

    word横排文本框怎么设置(word横排文本框怎么设置两行排列)

  • 快手买东西没有购买权限是什么意思(快手买东西没有取件码)

    快手买东西没有购买权限是什么意思(快手买东西没有取件码)

  • 拉黑还会显示已送达吗(拉黑还会显示已读吗)

    拉黑还会显示已送达吗(拉黑还会显示已读吗)

  • 华为cdyan00是什么型号(cdyan00是华为哪个型号)

    华为cdyan00是什么型号(cdyan00是华为哪个型号)

  • 微信商圈是什么模式(微信商圈圈店)

    微信商圈是什么模式(微信商圈圈店)

  • 行距和行间距一样么(行距行间距的区别)

    行距和行间距一样么(行距行间距的区别)

  • frontmic与麦克风有什么区别(freeform麦克风)

    frontmic与麦克风有什么区别(freeform麦克风)

  • 怎么知道苹果手机是国行还是港行或者是美版(怎么知道苹果手机什么时候激活的)

    怎么知道苹果手机是国行还是港行或者是美版(怎么知道苹果手机什么时候激活的)

  • 电脑上的ppt用什么软件打开(电脑上的ppt用什么软件)

    电脑上的ppt用什么软件打开(电脑上的ppt用什么软件)

  • 华硕笔记本wifi开关在哪里(华硕笔记本wifi驱动器怎么修复)

    华硕笔记本wifi开关在哪里(华硕笔记本wifi驱动器怎么修复)

  • qq怎么把性别去掉(qq怎么把性别弄掉)

    qq怎么把性别去掉(qq怎么把性别弄掉)

  • 个人收款码和商家收款码的区别(个人收款码和商用收款码有什么区别)

    个人收款码和商家收款码的区别(个人收款码和商用收款码有什么区别)

  • 查找我的iphone在哪里(查找我的iphone在线是对方在使用手机吗)

    查找我的iphone在哪里(查找我的iphone在线是对方在使用手机吗)

  • ios访问限制在哪(ios访问限制在哪里设置)

    ios访问限制在哪(ios访问限制在哪里设置)

  • switch怎么看是不是续航版(switch如何判断)

    switch怎么看是不是续航版(switch如何判断)

  • ddr5内存上市时间(ddr5内存定价)

    ddr5内存上市时间(ddr5内存定价)

  • ipad连不上iphone热点(ipad连不上iphone手机热点)

    ipad连不上iphone热点(ipad连不上iphone手机热点)

  • 没有收到升级推送怎么办 最新升级华为鸿蒙2.0的方法(系统更新没有推送)

    没有收到升级推送怎么办 最新升级华为鸿蒙2.0的方法(系统更新没有推送)

  • printnow.exe - printnow是什么进程 有什么作用

    printnow.exe - printnow是什么进程 有什么作用

  • cutftp.exe进程信息查询 cutftp是什么进程(进程process)

    cutftp.exe进程信息查询 cutftp是什么进程(进程process)

  • Dos Ojos自然公园里El Pit Cenote的潜水员,墨西哥金塔纳罗奥 (© Christia Vizl/Tandem Stills + Motion)(自然公园在哪)

    Dos Ojos自然公园里El Pit Cenote的潜水员,墨西哥金塔纳罗奥 (© Christia Vizl/Tandem Stills + Motion)(自然公园在哪)

  • 自有住房出租
  • 小规模纳税人已过开票截止日期禁止开票怎么办
  • 驾驶培训 增值税
  • 土地增值税会计核算
  • 当期所得税计入什么科目
  • 其他应收款有哪些情况
  • 公司报销生育津贴,孕期还需要去社保局备案吗
  • 预售收入是否可以退税
  • 商品卖亏的会计分录
  • 房地产按揭贷款是什么意思
  • 个人账户可以转公户吗?
  • 2018年上专科什么时候毕业
  • 建筑企业甲供材税收筹划
  • 建筑业增值税税率由11调整到10
  • 物业公司收的预存水费不够抵减怎么交税
  • 月末利润分配的账务处理
  • 税务年报网上怎么申报小微企业
  • 金税盘红字信息表金额大于原蓝票
  • 跨年销项税红字发票会计处理?
  • win11怎么看电脑配置
  • 园林公司采购岗位职责
  • 小规模纳税人无法开具增值税专用发票
  • 坏老狼告诉我们什么道理
  • win没有投影到此电脑怎么办
  • 销售返利应该怎么做账
  • phpstudy的ftp
  • linux中安装命令
  • php aop
  • 发生债务重组收益的分录
  • 有限责任公司股东会的职权有哪些?
  • 安装虚拟windows
  • 供热企业税收优惠政策
  • 稽查查补税款会计分录
  • 临时存款账户销户
  • pytorch_lightning.utilities.exceptions.MisconfigurationException: You requested GPUs: [1] But...
  • vue中过滤器有什么作用及详解
  • 企业季度所得税怎么算
  • php call stack
  • 福利费工会经费教育经费计提比例
  • php接口技术
  • js与或运算符
  • 交易性金融资产是什么意思
  • 用友会计科目增加二级
  • 未开票收入本月要计提增值税吗
  • 让渡资产使用权包括
  • 增值税直接计算法间接计算法举例
  • 双分录怎么做记账凭证
  • 工业企业新产品收入的调研报告
  • 年终奖金个人所得
  • 公户转私户的钱会退回吗
  • 制造费用如何控制
  • 工商营业执照变更网上怎么操作
  • 车间管理人员的福利费计入什么科目
  • 主营业务收入是含税还是不含税
  • mysql修改允许远程连接
  • centos6.10安装教程
  • xp电脑开机进入bios怎么办
  • 获取linux系统版本
  • centos6.9开启ssh服务
  • ubuntu15.04安装教程
  • ubuntu20.04安装vnc
  • ubuntu on xorg
  • windows7 运行
  • windows8窗口
  • vs opengl配置
  • 用python进行图像处理
  • iframe内容自适应缩放
  • node.js在网页制作中的作用
  • [置顶]公主大人接下来是拷问时间31
  • Unity3D游戏开发标准教程
  • 安卓 截图
  • Android SDK Manager无法更新的解决方案
  • auto.js获取剪切板内容
  • 国家税务系统电子税务局电话
  • 四川省一般纳税人资格证明
  • 返利是否合法
  • 下列关于消费税委托加工说法正确的是
  • 办理出口退税需要销售合同吗
  • 设区市是哪里
  • 广西地方税务局2017年公务员拟录用
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号