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

  • 小米hd设置在哪里关闭(小米手机hd模式)

    小米hd设置在哪里关闭(小米手机hd模式)

  • mini led背光技术原理(miniled背光是什么)

    mini led背光技术原理(miniled背光是什么)

  • oppo reno防水吗(opporeno10防水吗)

    oppo reno防水吗(opporeno10防水吗)

  • 苹果手机听觉当前线路不可用什么意思啊(苹果手机里听觉是干嘛用的?)

    苹果手机听觉当前线路不可用什么意思啊(苹果手机里听觉是干嘛用的?)

  • vivo手机刷机还要密码,怎么办(vivo手机刷机还原所有设置还要密码)

    vivo手机刷机还要密码,怎么办(vivo手机刷机还原所有设置还要密码)

  • 华为手机解除微信加密怎么弄(华为手机解除微信绑定的银行卡)

    华为手机解除微信加密怎么弄(华为手机解除微信绑定的银行卡)

  • 高通850和i5性能对比(i5和高通850的区别有多大)

    高通850和i5性能对比(i5和高通850的区别有多大)

  • 商业机构的域名是什么(商业机构的域名后缀是什么)

    商业机构的域名是什么(商业机构的域名后缀是什么)

  • 数据存储有哪几种方式(数据存储有哪几种)

    数据存储有哪几种方式(数据存储有哪几种)

  • 华为p40pro多重(华为p40p+多重)

    华为p40pro多重(华为p40p+多重)

  • 抖音里的共同联系人是怎么来的(抖音里的共同联系人怎么不见了)

    抖音里的共同联系人是怎么来的(抖音里的共同联系人怎么不见了)

  • 小米9能升级miui12吗(小米9能升级miui12.5吗)

    小米9能升级miui12吗(小米9能升级miui12.5吗)

  • 抖音点赞后马上取消对方能看到吗(抖音点赞后马上拉黑对方能看到吗)

    抖音点赞后马上取消对方能看到吗(抖音点赞后马上拉黑对方能看到吗)

  • 抖音显示在线什么意思(抖音显示在线是什么状态)

    抖音显示在线什么意思(抖音显示在线是什么状态)

  • win10键盘鼠标全失灵(win10键盘鼠标全失灵电脑死机)

    win10键盘鼠标全失灵(win10键盘鼠标全失灵电脑死机)

  • 为什么手机充了话费还是停机(为什么手机充了话费没有短信提醒)

    为什么手机充了话费还是停机(为什么手机充了话费没有短信提醒)

  • 钉钉露脸怎么放大(钉钉露脸怎么设置)

    钉钉露脸怎么放大(钉钉露脸怎么设置)

  • 怎样下载手机铃声歌曲到手机上(怎样下载手机铃声来电铃声华为)

    怎样下载手机铃声歌曲到手机上(怎样下载手机铃声来电铃声华为)

  • 候补购票退单什么时间退款(候补车票退单)

    候补购票退单什么时间退款(候补车票退单)

  • 淘宝确认收货后钱多久到卖家账户(淘宝确认收货后如何退款)

    淘宝确认收货后钱多久到卖家账户(淘宝确认收货后如何退款)

  • qq怎么弄透明头像(在qq里怎么弄透明头像(要显示背景的))

    qq怎么弄透明头像(在qq里怎么弄透明头像(要显示背景的))

  • wim格式用手机怎么打开(wiz格式手机怎么打开)

    wim格式用手机怎么打开(wiz格式手机怎么打开)

  • 华为性能模式提升多少(华为性能模式提升大吗)

    华为性能模式提升多少(华为性能模式提升大吗)

  • 苹果手机怎样蹭热点别人的(苹果手机怎样蹭网不用密码)

    苹果手机怎样蹭热点别人的(苹果手机怎样蹭网不用密码)

  • 荣耀note10能不能开空调(荣耀note10能不能插内存卡)

    荣耀note10能不能开空调(荣耀note10能不能插内存卡)

  • 删除并拉黑后就永远加不上对方了吗(删除并拉黑后就没有了吗)

    删除并拉黑后就永远加不上对方了吗(删除并拉黑后就没有了吗)

  • WPS重用幻灯片在哪(wps2019重用幻灯片在哪)

    WPS重用幻灯片在哪(wps2019重用幻灯片在哪)

  • 充电仓怎么看充满电(充电仓怎么看充满电一直是红的)

    充电仓怎么看充满电(充电仓怎么看充满电一直是红的)

  • 智联招聘如何设置黑名单(智联招聘如何设置简历查看权限)

    智联招聘如何设置黑名单(智联招聘如何设置简历查看权限)

  • 考研408复习思路,学习方法(考研408怎么样)

    考研408复习思路,学习方法(考研408怎么样)

  • 以前年度损益调整
  • 生产型企业进项税加计扣除
  • 计提附加税金额
  • 表见代理通俗
  • 增值税普票税额怎么算出来的
  • 哪些进项税额不可以抵扣
  • 红字发票和蓝字一样吗
  • 出口企业免抵税额要作进项转出吗
  • 金蝶财务软件固定资产模块固定资产调拨
  • 取得失控发票
  • 结转产成品会计分录怎么做
  • 银行贷款利息支出汇算清缴需要调整吗
  • 个人借款无法收回确认坏账账务处理
  • 核定征收公司有什么用
  • 过了征期还能报税吗
  • 建筑业附加税税率是多少
  • 个体户超过3万怎么纳税
  • 计提个人负担的社会保险费分录
  • 差额征税可以开发票吗
  • 公司没成本票怎么暂估
  • 交易性金融资产公允价值变动计入
  • 对公支出没有发票计入什么科目
  • 关联公司代付款帐怎么做
  • 如何设置win10电脑开机不黑屏
  • PHP:xml_set_character_data_handler()的用法_XML解析器函数
  • 如何才能显示效果更好
  • php中字符串函数
  • 企业所得税汇算清缴
  • 管理费用的会计编码
  • 零基础java从入门到精通
  • php+mysql+apache
  • 股权投资差额怎么算
  • 制造费用期末怎么结转
  • thinkphp版本区别
  • 个人独资企业都需要交什么税
  • 命令行修改mac地址
  • 钱进公账怎么转账给别人
  • 先收到保险公司赔付然后赔给顾客医药费怎么做帐
  • 结转本期损益怎么看亏损
  • phpcms 生成首页
  • 如何查看发票是否作废
  • 应付账款发生坏账怎么办
  • 专家评审费如何入账
  • 转账支付水电费
  • 建筑行业有哪些生意可以做
  • 装修费没发票怎么记账
  • 多交了社保
  • 母公司与子公司税务关系
  • 以前年度损益这个科目
  • 预收账款账务处理流程图
  • 公司运营成本如何计算
  • 职工薪酬包括哪四项内容
  • win8无法进入系统
  • win10预览版21277
  • 怎么修改注册表的权限
  • Freebsd7.0 Apache2.2+MySQL5+PHP5安装和配置方法
  • win7微软账户
  • 隐藏控制台窗口
  • 系统闹钟设置
  • linux的shm共享内存
  • 关于session的用法哪些是错误的
  • 好好了解 英文
  • node.js配置
  • nodejs中的事件循环的执行顺序
  • Android 中的 TableLayout 继承自
  • preorder遍历
  • 微信小程序实战入门 第2版
  • 简述javascript执行原理
  • node js模块
  • Android5.1 SystemUI 启动流程
  • javascriptz
  • Unity uGui RawImage 渲染小地图
  • android draglistview中拖动异常显示,无法移动到原先位置
  • python中创建类对象
  • js新年倒计时
  • 江苏省税务局官网电话
  • 补充协议需要双方签字盖章吗
  • 电子缴款凭证可以用于报销吗
  • 在电脑上怎样做word的文档
  • 物业优质服务我们在行动
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设