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

  • ipad1越狱后如何装软件(ipad1越狱教程)(ipad越狱后能干什么)

    ipad1越狱后如何装软件(ipad1越狱教程)(ipad越狱后能干什么)

  • 电脑关机慢如何设置(电脑关机慢怎么办)(电脑关机很慢很慢)

    电脑关机慢如何设置(电脑关机慢怎么办)(电脑关机很慢很慢)

  • 新浪邮箱网页版设置在哪(新浪邮箱网页版手机)

    新浪邮箱网页版设置在哪(新浪邮箱网页版手机)

  • 小米6x尺寸是多少(小米6x多宽多高)

    小米6x尺寸是多少(小米6x多宽多高)

  • 动图保存到手机不动了(动图保存到手机不动了怎么办)

    动图保存到手机不动了(动图保存到手机不动了怎么办)

  • 锤子pro2手机死机怎么重启(锤子pro2突然黑屏死机)

    锤子pro2手机死机怎么重启(锤子pro2突然黑屏死机)

  • 手机摄像头坏跟主板有关系吗(手机摄像头坏跟什么有关)

    手机摄像头坏跟主板有关系吗(手机摄像头坏跟什么有关)

  • 微星笔记本是哪国的(微星笔记本是哪个公司)

    微星笔记本是哪国的(微星笔记本是哪个公司)

  • 在设置中切换输出设备是什么意思(在设置中切换输出设备怎么弄)

    在设置中切换输出设备是什么意思(在设置中切换输出设备怎么弄)

  • 一亿像素手机有哪些(一亿像素手机有什么区别)

    一亿像素手机有哪些(一亿像素手机有什么区别)

  • 新申请的qq号为什么不能登录微信(新申请的QQ号为何玩不了梦之队?)

    新申请的qq号为什么不能登录微信(新申请的QQ号为何玩不了梦之队?)

  • 不要挂机正在通话中什么意思

    不要挂机正在通话中什么意思

  • 网络设备具体有哪些(网络设备具体有哪些品牌)

    网络设备具体有哪些(网络设备具体有哪些品牌)

  • 直播限流怎么解决(直播限流怎么解除)

    直播限流怎么解决(直播限流怎么解除)

  • 滴滴订单少是什么原因(滴滴出行这两天订单减少)

    滴滴订单少是什么原因(滴滴出行这两天订单减少)

  • oppo手机摔黑屏怎么办(oppo手机摔黑屏怎么导出资料)

    oppo手机摔黑屏怎么办(oppo手机摔黑屏怎么导出资料)

  • 华为手机怎么调闹钟一次(华为手机怎么调回彩色屏)

    华为手机怎么调闹钟一次(华为手机怎么调回彩色屏)

  • 拼多多有没有运费险(拼多多有没有运费钱)

    拼多多有没有运费险(拼多多有没有运费钱)

  • 华为dratl00是什么型号(华为draal00)

    华为dratl00是什么型号(华为draal00)

  • 微博视频怎么保存到手机(微博视频怎么保存到手机相册)

    微博视频怎么保存到手机(微博视频怎么保存到手机相册)

  • iphone7有耳机孔吗(iphone7插耳机的地方在哪)

    iphone7有耳机孔吗(iphone7插耳机的地方在哪)

  • 怎样删除电脑上的小象壁纸(怎样删除电脑上的文件)

    怎样删除电脑上的小象壁纸(怎样删除电脑上的文件)

  • wps怎么清除多余的表格(wps怎么清除多余格子格式)

    wps怎么清除多余的表格(wps怎么清除多余格子格式)

  • iphone xs怎么设置铃声(iPhone xs怎么设置动态锁屏壁纸)

    iphone xs怎么设置铃声(iPhone xs怎么设置动态锁屏壁纸)

  • qq被冻结怎么办手机(qq涉嫌违规注册qq被冻结怎么办)

    qq被冻结怎么办手机(qq涉嫌违规注册qq被冻结怎么办)

  • 埃克斯穆尔国家公园斯托克佩罗公地,英国英格兰 (© David Noton/Alamy)(埃莫尔斯)

    埃克斯穆尔国家公园斯托克佩罗公地,英国英格兰 (© David Noton/Alamy)(埃莫尔斯)

  • 实收资本变动额怎么算
  • 补提盈余公积的分录
  • 工程保险谁负责
  • 连锁店每个店都要独立核算吗
  • 非专利技术转让计入什么科目
  • 公司没有业务了 可以办理停业
  • 季度不超过9万
  • 企业没有进项发票又开出很多发票
  • 当期处置子公司,当期还纳入合报范围嘛
  • 超市购物卡发票可以报销吗
  • 土地增值税筹划实战
  • 材料税款抵扣
  • 退回剩余的工程物资
  • 其他业务收入的核算内容
  • 电子发票可以认证几次
  • 案例分析个人总结报告
  • 工程交税需要什么资料
  • 通讯费企业所得税
  • 电商一般纳税人如何报税
  • 发放活动奖金支出怎么入账
  • 1697509310
  • 小企业成本核算方法移动加权平均法
  • 以土地使用权出资入股未办过户能否抽回
  • 房地产企业的沙盘模型制作费会计处理
  • 不确认收入要结转成本吗
  • laravel如何使用前端的纯静态页
  • wnba艾琳娜多恩
  • php中的异常和错误怎么写
  • php批量更新数据库
  • 房屋租赁费发票备注栏需要写什么?
  • php深度分析
  • js返回上一步操作
  • 增值税和所得税区别
  • 前端get请求传数组
  • 创建command对象
  • php如何安装配置
  • 免税农产品包括30万元吗
  • 医院职工医疗保险报销比例
  • 税收收入退还书有时间限制吗
  • 所得税弥补亏损年限10
  • 专票不认证有什么风险
  • python一元二次方程求根
  • mac中mysql应该怎么运行
  • php网站根目录
  • 同一控制下企业合并和非同一控制下企业合并的区别
  • access数据库如何
  • 增值税药品发票明细
  • 城镇土地使用税的计税依据
  • 生产企业免抵退是什么意思
  • 在建工程借款利息计入哪里
  • 银行日记账记错了怎么办
  • 股东实收资本超额到位
  • 支付贷款利息属于筹资活动吗
  • 所得税费用的确认分录
  • 代扣的应由职工个人负担的社会保险费计入什么科目
  • 会计核算和监督两项基本会计职能是相辅相成
  • excel日记账系统的设置
  • freebsd怎么样
  • win7怎么用耳机听歌
  • 如何更改win7
  • win10开始无法打开
  • 电脑硬盘磁盘是什么材料
  • NkbMonitor.exe - NkbMonitor是什么进程文件 有什么作用
  • win7 注册表 ahci
  • win7系统无法更改主题
  • win8系统安装包
  • css 网页布局
  • opengl learn
  • Node.js中的什么模块是用于处理文件和目录的
  • 同一内容复制到多个单元格
  • Unity3d MonoDevelop格式化代码
  • android基础入门教程
  • jqueryui
  • 安卓开发常见问题
  • 云南人社12333app官网
  • 运费没有发票怎么报销
  • 一般纳税人的进项票必须当月认证吗?
  • 天津环保网站官网
  • 税务机关垂直领导
  • 税务津贴提高1100
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设