重磅更新,unocss终于可以完美使用px单位了
前言
不管是unocss
还是tailwindcss
和windicss
,默认的单位都是rem
,这有一定的设计理念,但其实这对于习惯使用px
单位的人来说不太友好,有相当一部分人因为这点而放弃使用原子化css
那么,有没有办法使用px呢,其实三大原子css框架都支持px的写法,比如下面这样
使用 w-[100px]
就可以表示 width: 100px;
好了,本篇文章水完了~
哈哈,开玩笑的
虽然这种方式确实可以实现使用px单位,但是有以下两个问题
- 不够简洁,要多写很多字符,别看只是4个字符,4个字符完全可以多写一个原子样式了
- 不能使用属性的方式编写,很丑,且会报错(Vue项目),如下图
如果 w-100
能表示 width: 100px;
是不是很完美呢,本篇文章要介绍的就是要实现这样的一个效果,
铺垫完毕,上正文
如何实现 w-100 = width: 100px
方案一
之前我发布过一篇关于unocss的文章,里面有介绍一种让 w-100
表示 width: 100px;
的方法,就是修改html的 font-size
大家都知道 rem
是相对于 html
的 font-size
计算的, html
默认 font-size
是 16px
, 也就是说 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
- 安装插件
npm i @unocss/preset-rem-to-px -D
- 在unocss的配置文件中集成,不清楚unocss基础配置的同学可以翻看我以前的文章
unocss.config.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
看到这是不是很熟悉,没错, html
的 font-size
默认值刚好也是 16
接下来就简单了,按照方案一的思路,只需要将 baseFontSize 改成 4
就行了
unocss.config.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,毕竟使用默认预设也很容易写出很丑的页面,关键还得看个人的美感。
如果文章对你有帮助,请点赞或者关注,这对我很重要,我将持续分享更多实用的技术知识~
转载自:https://juejin.cn/post/7262975395620618298