likes
comments
collection
share

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

作者站长头像
站长
· 阅读数 82

前言

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

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

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

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

好了,本篇文章水完了~

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

哈哈,开玩笑的

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

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

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

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

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

铺垫完毕,上正文

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

方案一

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

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

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

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

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

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

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

很明显,这对于习惯了用 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. 安装插件
npm i @unocss/preset-rem-to-px -D
  1. 在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 的可以先安装一下

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

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

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

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

看到这是不是很熟悉,没错, htmlfont-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,
    }),
  ],
})

我们再看下效果

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

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

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

结论

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

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


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

转载自:https://juejin.cn/post/7262975395620618298
评论
请登录