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

  • 太空寄信怎么寄(太空信怎么写)

    太空寄信怎么寄(太空信怎么写)

  • 苹果电话声音小了怎么恢复(苹果电话声音小调哪里)

    苹果电话声音小了怎么恢复(苹果电话声音小调哪里)

  • cdr文件打不开怎么办(cdr打开不了怎么办)

    cdr文件打不开怎么办(cdr打开不了怎么办)

  • 微信只能听筒模式了怎么办(微信只能听听筒)

    微信只能听筒模式了怎么办(微信只能听听筒)

  • 计算器mu什么意思(计算器中mu)

    计算器mu什么意思(计算器中mu)

  • 怎么设置对方能听到手机铃声(怎么设置对方能发消息 自己看不到)

    怎么设置对方能听到手机铃声(怎么设置对方能发消息 自己看不到)

  • 电容式接近开关可以检测什么(电容式接近开关图片)

    电容式接近开关可以检测什么(电容式接近开关图片)

  • boss直聘头像必须是自己的么(boss直聘头像要用真实的吗)

    boss直聘头像必须是自己的么(boss直聘头像要用真实的吗)

  • 什么是液态硅胶手机壳(什么是液态硅胶娃娃)

    什么是液态硅胶手机壳(什么是液态硅胶娃娃)

  • airpods pro可以调节音量吗(airpods pro能调节音量么)

    airpods pro可以调节音量吗(airpods pro能调节音量么)

  • 显卡70多度正常吗(显卡70多度正常么)

    显卡70多度正常吗(显卡70多度正常么)

  • 微信5千步是多少公里(微信五千步要走多久)

    微信5千步是多少公里(微信五千步要走多久)

  • 淘宝联盟自己买东西有佣金吗(淘宝联盟自己买东西怎么返利)

    淘宝联盟自己买东西有佣金吗(淘宝联盟自己买东西怎么返利)

  • 安卓11新特性(安卓11的新特性)

    安卓11新特性(安卓11的新特性)

  • 联想y7000p怎么关logo灯(联想y9000p2023款)

    联想y7000p怎么关logo灯(联想y9000p2023款)

  • 一直开着nfc费电吗(一直开启nfc费电么)

    一直开着nfc费电吗(一直开启nfc费电么)

  • 手机关机微信运动显示么(手机关机微信运动会显示0吗)

    手机关机微信运动显示么(手机关机微信运动会显示0吗)

  • 苹果a1524是什么机型(苹果a1524是什么型号)

    苹果a1524是什么机型(苹果a1524是什么型号)

  • 华为双卡怎么切换拨号(华为双卡怎么切换微信)

    华为双卡怎么切换拨号(华为双卡怎么切换微信)

  • 苹果x反向充电设置在哪(苹果x反向充电在哪里设置)

    苹果x反向充电设置在哪(苹果x反向充电在哪里设置)

  • 抖音怎么隐身看直播(抖音怎么隐身看主页)

    抖音怎么隐身看直播(抖音怎么隐身看主页)

  • 怎么把两页的内容调成一页(怎么把两页的内容打印到一张纸上)

    怎么把两页的内容调成一页(怎么把两页的内容打印到一张纸上)

  • iphonexrhome键怎么调出来(iphonexrhome键怎么隐藏)

    iphonexrhome键怎么调出来(iphonexrhome键怎么隐藏)

  • iphonex出声孔清理(苹果x的声音孔怎么清理)

    iphonex出声孔清理(苹果x的声音孔怎么清理)

  • 对于HashMap的容量的一些分析(hashmap的使用场景)

    对于HashMap的容量的一些分析(hashmap的使用场景)

  • 医院这么开发票
  • 发生租赁费用怎么做账
  • 增值税 普通税
  • 材料采购合同需要注意什么
  • 餐饮业可以开增值税专用发票吗?
  • 工程施工计入资产负债表
  • 电子发票如何发给用截图发送可以吗?
  • 个人车卖给公司能抵税吗
  • 合理合法的纳税人是谁
  • 复式记账法哪本书提到过?
  • 发票过期了还能抵扣吗
  • 老板投入资金入什么科目
  • 给供应商付款怎么做分录
  • 股东往来款怎么处理
  • 供热企业采暖费收入免征增值税政策解读
  • 事业单位属于一级单位吗
  • 代理进口产品需要什么手续
  • 增值税专用发票怎么开
  • 怎么用手撕胶带图解
  • 增值税发票过期了,对方可以重开吗
  • 适用增值税差额征税的小规模纳税人
  • 留抵退还增值税
  • 推广费属于什么科目
  • 增值税开票系统客服电话
  • nginx不支持ipv6
  • php编写
  • netsurf.exe - netsurf是什么进程 有什么用
  • 计提利息会计分录怎么做
  • 收到违约金如何入账
  • hottray.exe是什么进程 有什么作用 hottray进程查询
  • 暴风雪的寒冷
  • php 装饰器
  • php bind_result
  • 因质量问题免费赔偿
  • php 创建对象
  • 前端基础入门
  • 微信php源码
  • 一个残疾证一年单位免多少税2023
  • 人力为主的公司名称
  • 其他权益工具确认投资损失的账务处理
  • python的用途
  • MongoDB的mongo shell常用操作方法及操作脚本笔记
  • 土地使用权是指企业所拥有的
  • 个税申报赡养老人可以填公婆吗
  • 社保滞纳金所得税
  • sql server 2005 数据库还原
  • 合伙企业可以列入法人吗
  • 合并报表中的抵消分录是什么意思?
  • 如何查询继续教育ic卡号
  • 陕西省跨区域企业所得税征收
  • 公允价值变动损益借贷方向增减
  • 支出应计入管理费用,而且要根据其发生额
  • 买赠销售账务处理
  • 个人原因指什么
  • 建造合同收入怎么算
  • 什么是经营所得现金
  • win10预览版和正式版区别
  • windows vista在哪里
  • ubuntu :wq
  • linux命令sed -i
  • fedora14虚拟机安装教程
  • PureVoice.exe - PureVoice是什么进程 有什么用
  • windows7键盘
  • jquery禁止点击事件
  • jquery()
  • js去除hover样式
  • js处理跨域方式及原理
  • nodejs跳转到指定页面
  • js跨域请求json数据
  • 将光标定位于输入端
  • JQuery datepicker 用法详解
  • unity3d2019教程
  • js判断div是否存在
  • python做脚本语言怎么用
  • 小微企业税务优惠政策
  • 无锡市高新区税务局张贤平
  • 青岛税务局局长是什么级别?
  • 税务清查工作总结
  • 德国对外投资法律劣势有哪些方面
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设