重磅更新,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,毕竟使用默认预设也很容易写出很丑的页面,关键还得看个人的美感。


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

相关推荐
jay神21 分钟前
基于flask+vue的电影可视化与智能推荐系统
vue.js·爬虫·python·flask·电影可视化系统
患得患失94921 分钟前
【css】【面试提问】css经典问题总结
前端·css
JosieBook40 分钟前
【web应用】vue3前端框架怎么修改logo?
vue.js
夏天想2 小时前
vue页面目录菜单有些属性是根据缓存读取的。如果缓存更新了。希望这个菜单也跟着更新。
前端·vue.js·缓存
Python涛哥2 小时前
前端流行框架Vue3教程:20. 插槽slot(2)
前端·javascript·vue.js
苹果酱05672 小时前
经典Java面试题的答案——Java 基础
java·vue.js·spring boot·mysql·课程设计
百锦再6 小时前
Vue环境下数据导出PDF的全面指南
前端·javascript·vue.js·python·django·pdf·pygame
菜鸟una9 小时前
【微信小程序 + 高德地图API 】键入关键字搜索地址,获取经纬度等
前端·vue.js·微信小程序·小程序·typescript
海天胜景11 小时前
vue3 el-table 行号
javascript·vue.js·ecmascript
小赖同学啊11 小时前
深度解析 Element Plus
前端·javascript·vue.js