位置: 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浏览器百度网盘插件)

  • 促销是什么,线下零售企业怎样向电商学促销(促销指什么)

    促销是什么,线下零售企业怎样向电商学促销(促销指什么)

  • iphone下载的音乐文件在哪(iphone下载的音乐文件)

    iphone下载的音乐文件在哪(iphone下载的音乐文件)

  • 华为手机悬浮球怎么关(华为手机悬浮球怎么关闭)

    华为手机悬浮球怎么关(华为手机悬浮球怎么关闭)

  • 为什么在刷宝上不能发评论(刷宝为什么取不出来钱)

    为什么在刷宝上不能发评论(刷宝为什么取不出来钱)

  • 开冰箱门是平移还是旋转现象(开冰箱门是平移还是斜移)

    开冰箱门是平移还是旋转现象(开冰箱门是平移还是斜移)

  • 微信别人看你朋友圈你知道吗(微信别人看你朋友圈有提示吗)

    微信别人看你朋友圈你知道吗(微信别人看你朋友圈有提示吗)

  • 苹果se2什么时候上市(苹果se2什么时候上市图片及价格)

    苹果se2什么时候上市(苹果se2什么时候上市图片及价格)

  • 什么叫线性相关(什么叫线性相关线性代数)

    什么叫线性相关(什么叫线性相关线性代数)

  • 华为如何删除应用软件(华为怎样删除应用程序)

    华为如何删除应用软件(华为怎样删除应用程序)

  • 三星s20型号(三星S20型号SM-G9860)

    三星s20型号(三星S20型号SM-G9860)

  • 移动短信删除了还能恢复吗(移动短信删除了怎么恢复回来)

    移动短信删除了还能恢复吗(移动短信删除了怎么恢复回来)

  • 微信记录步数的小程序叫什么(微信记录步数的时候手机拿在手里和放在兜里一样吗)

    微信记录步数的小程序叫什么(微信记录步数的时候手机拿在手里和放在兜里一样吗)

  • 怎样发图片加文字到朋友圈(怎样发图片加文字微信)

    怎样发图片加文字到朋友圈(怎样发图片加文字微信)

  • 电脑窗口的意思(电脑窗口的意思简单)

    电脑窗口的意思(电脑窗口的意思简单)

  • 快手可以图片评论吗(快手图片评论影视播放量吗)

    快手可以图片评论吗(快手图片评论影视播放量吗)

  • 85定焦使用技巧(85 定焦镜头)

    85定焦使用技巧(85 定焦镜头)

  • 自己发出的抖音怎么删除(自己发出的抖音怎样册除?)

    自己发出的抖音怎么删除(自己发出的抖音怎样册除?)

  • 华为开发者模式怎么关(华为开发者模式干嘛的)

    华为开发者模式怎么关(华为开发者模式干嘛的)

  • 另存为怎么操作(word文件另存为怎么操作)

    另存为怎么操作(word文件另存为怎么操作)

  • 手机拨号后黑屏怎么回事(手机拨号后黑屏怎么回事在什么设置中解除?)

    手机拨号后黑屏怎么回事(手机拨号后黑屏怎么回事在什么设置中解除?)

  • 抖音右上角有个黄点(抖音右上角有个闪电标志是什么意思)

    抖音右上角有个黄点(抖音右上角有个闪电标志是什么意思)

  • eps文件怎么打开(如何分割pdf文件)

    eps文件怎么打开(如何分割pdf文件)

  • 支付宝隐私开关在哪里(支付宝隐私开关打开的的为什么别人还是无法转账)

    支付宝隐私开关在哪里(支付宝隐私开关打开的的为什么别人还是无法转账)

  • 苹果11怎么双卡双待(苹果11怎么双卡怎么装)

    苹果11怎么双卡双待(苹果11怎么双卡怎么装)

  • 华硕笔记本连不了网怎么办(华硕笔记本连不上5g无线网络)

    华硕笔记本连不了网怎么办(华硕笔记本连不上5g无线网络)

  • iphonexs无法关机(苹果xs手机无法关机)

    iphonexs无法关机(苹果xs手机无法关机)

  • 手机接通后听不到对方声音(手机接通后听不见说话)

    手机接通后听不到对方声音(手机接通后听不见说话)

  • 小型微利企业税率2023
  • 印花税不通过税金及附加核算
  • 个人给单位做事怎么开发票
  • 退回多交城建税税金会计分录
  • 企业收到利息发票怎么做分录
  • 外贸企业当月没交税
  • 社保代理公司的合作协议
  • 应交消费税通过什么科目核算
  • 外币借款汇兑差额资本化额怎么计算
  • 高温补贴能以别的形式发放吗
  • 预缴税款的完税证明单
  • 公共电话亭的话费收入如何做税务处理呢?
  • 公司收到一张专用发票
  • 收到利息计入哪个会计科目
  • 怎么作废未使用的发票
  • 消费税组成计税价
  • 发票报账的基本流程
  • 员工因公负伤期间公司怎么开工资
  • 企业捐赠现金支出应在哪个项目反应
  • 金蝶kis云专业版原材料数量怎么录入
  • 怎么处理有问题的货物
  • 资本公积的借方和贷方各表示什么
  • 法院收到诉讼费多久可以收到传票
  • 公司减少注册资本时,应当自作出减少
  • 生产型企业公司有哪些
  • 入账价值和账面余额一样吗
  • 招标场地费怎么收
  • 公司入股的钱叫什么
  • 错账改正方法
  • 进口增值税的账务处理
  • 固定资产付款流程
  • 今日元宵节图片
  • php 动态调用类方法
  • yolov5训练参数说明
  • php preg_quote
  • php批量删除文件
  • 中兴网管操作手册
  • 小程序微信认证
  • 投稿p2
  • 预缴城建税税率
  • python中列表的作用
  • pytest unittest
  • 差旅费报销金额大于实际发生金额
  • 金蝶做账流程视频
  • 增值税发票是记账联还是抵扣联
  • 基本户变更经营范围需要什么材料
  • 进项税大于销项税怎么做分录
  • 个体工商户开具房屋租赁发票
  • 转账支付水电费
  • 溢价发行可转换债券 利息调整在贷方吗
  • 企业设备维修
  • 软件企业确认收入
  • 工资计提和发放账务处理
  • 职工住房补贴能否计入工资总额在税前扣除?
  • 银行本票的使用仅限于
  • 银行对账单和回单有什么区别
  • ubuntu开启图形化界面
  • 本地硬盘满了怎么办
  • ubuntu wine安装的软件怎么运行
  • mac如何强制关机开机
  • linux修改密码认证令牌错误
  • win8系统设置
  • Win7系统打开D盘文件后怎么没有后退箭头
  • win7文件夹选项在哪里打开
  • 如何在win7上打开win10软件
  • excel的基本数据类型
  • 上传图片 js
  • python内置函数什么用来返回序列中的最大元素
  • jquery动态设置css
  • meta-inf文件夹在哪
  • 基于javascript的毕业设计
  • python语言基本语法
  • javascript怎么用
  • java script
  • 江苏税务登录密码是几位
  • 资源税的税目,税率依照税目税率表执行
  • 南京市国家税务局溧水分局
  • 强化管理定义
  • 所得税与增值税区别
  • 税务非正常认定条件
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设