重磅更新,unocss终于可以完美使用px单位了

前言

不管是unocss还是tailwindcsswindicss,默认的单位都是rem,这有一定的设计理念,但其实这对于习惯使用px单位的人来说不太友好,有相当一部分人因为这点而放弃使用原子化css

那么,有没有办法使用px呢,其实三大原子css框架都支持px的写法,比如下面这样

使用 w-[100px] 就可以表示 width: 100px;

好了,本篇文章水完了~

哈哈,开玩笑的

虽然这种方式确实可以实现使用px单位,但是有以下两个问题

  1. 不够简洁,要多写很多字符,别看只是4个字符,4个字符完全可以多写一个原子样式了
  2. 不能使用属性的方式编写,很丑,且会报错(Vue项目),如下图

如果 w-100 能表示 width: 100px; 是不是很完美呢,本篇文章要介绍的就是要实现这样的一个效果,

铺垫完毕,上正文

如何实现 w-100 = width: 100px

方案一

之前我发布过一篇关于unocss的文章,里面有介绍一种让 w-100 表示 width: 100px; 的方法,就是修改html的 font-size

大家都知道 rem 是相对于 htmlfont-size 计算的, html 默认 font-size16px, 也就是说 1rem = 16px

但是, 在原子css的默认预设中,1单位 = 0.25rem,如下图

也就是 4单位 = 1rem,所以要表示 100px(6.25rem) 得写成 25单位

很明显,这对于习惯了用 px 单位的人来说,心算成本太高了,有时候甚至得拿出计算器来算一下

当然,也有更简单的速算方法,只需要记住 1单位 = 4px 就行了,100 / 4 = 25

那有没有方式可以不计算呢,答案肯定是有的,既然我们知道了计算规则,那么只需要修改 html 的 font-size 就行了,接下来只需要做下简单的数学推导,已知 1单位 = 0.25 \* rem, 什么情况下 100单位 = 100px

1单位 = 0.25 * rem --> 100单位 = 25 * rem -> 100px = 25 * rem --> rem = 4px

答案就是将 html 的 font-size 修改成 4px,然后就不用再去计算了, w-1 就是 width: 1px;, w-100 就是 width: 100px

方案二(推荐)

使用插件 @unocss/preset-rem-to-px,这个插件的作用就是将 unocss 的预设单位转换成px

  1. 安装插件
cmd 复制代码
npm i @unocss/preset-rem-to-px -D
  1. 在unocss的配置文件中集成,不清楚unocss基础配置的同学可以翻看我以前的文章

unocss.config.js

js 复制代码
import { defineConfig, presetAttributify, presetUno } from 'unocss'
import presetRemToPx from '@unocss/preset-rem-to-px'

export default defineConfig({
  presets: [
    presetUno(),
    presetAttributify(),
    presetRemToPx(),
  ],
})

然后我们可以看到已经生效了,单位改成 px 了(没有安装vscode插件 unocss 的可以先安装一下

不过这跟 rem 其实差不多,还是 1单位 = 4px,而我们要的效果是 1单位 = 1px

我们点进这个插件的源码看下,发现 presetRemToPx 可以接收一个参数 baseFontSize,默认值是 16

看到这是不是很熟悉,没错, htmlfont-size 默认值刚好也是 16

接下来就简单了,按照方案一的思路,只需要将 baseFontSize 改成 4 就行了

unocss.config.js

js 复制代码
import { defineConfig, presetAttributify, presetUno } from 'unocss'
import presetRemToPx from '@unocss/preset-rem-to-px'

export default defineConfig({
  presets: [
    presetUno(),
    presetAttributify(),
    presetRemToPx({
      baseFontSize: 4,
    }),
  ],
})

我们再看下效果

结论

官方的默认预设(1单位 = 0.25rem)存在一定的合理性,为什么 原子css 可以很轻松的设计出很舒适的页面呢,正是因为它的预设是符合UI设计的理念的,我们将 1单位 改成 1px 这固然可以最大限度的提升我们写原子样式的爽度,但也不可避免的容易写出不协调的样式。

至于怎么选择还是得看个人,不过如果让我选我还是选择将 1单位 改成 1px,毕竟使用默认预设也很容易写出很丑的页面,关键还得看个人的美感。


如果文章对你有帮助,请点赞或者关注,这对我很重要,我将持续分享更多实用的技术知识~

相关推荐
东东5165 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
layman05287 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔8 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
_OP_CHEN8 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒8 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库8 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
晓晓莺歌8 小时前
vue3某一个路由切换,导致所有路由页面均变成空白页
前端·vue.js
~小仙女~9 小时前
为什么垂直居中比水平居中难?
css·垂直居中
web打印社区13 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO13 小时前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素