Varlet Vue3 组件库 3.2 发布 | 拥抱 Nuxt、桌面端体验增强、支持原子化框架

写在前面

自上一篇文章 Vue3 组件库 Varlet v3.0.0 发布了!支持 Material Design 3 已经过去了一个月了,这一个月我们收到了不少的用户反馈,主要的几个关键词是:Nuxt3、Material Design 3 主题配色、桌面端支持、unocss 支持、tailwindcss 支持,为了不辜负期待,所以我们在这一个月的时间里针对其做了一些更新。

桌面端支持

作者为不了解 varlet 的同学们简单介绍一下,varlet 是一个同时支持 material design 2 和 material design 3 设计系统的移动端组件库 。可能有同学会产生疑问,移动端组件库有可能支持桌面端应用么?答案是肯定的。作者早年一直是 vant2 的使用者,早在那个时期 vant 就已经通过自定义 touch 事件的方案解决了这一问题。varlet 初期也借鉴了这种设计,详细可以 参考源码,很容易理解

简单来说,varlet 一开始就是支持桌面端的,但是体验一般,只能说是勉强能用

桌面端体验增强

简单分析一下移动端组件在桌面端上的先天不足。

  1. 键盘交互缺失
  2. 组件 tab 导航缺失
  3. 组件 focusing 反馈缺失
  4. 组件 hovering 反馈缺失

这里举几个简单的例子,让同学们直观感受一下

  1. 下拉菜单通常情况是允许通过键盘上下左右进行选择的,空格回车是允许选中的,esc 是允许关闭的
  2. 单选框组通常情况是允许通过键盘上下左右进行切换选项的
  3. 模态框通常情况是允许通过 esc 关闭的,且需要按照弹出的顺序逆序进行关闭(后弹出的先关闭)
  4. 还有非常非常非常非常非常多......

这些场景在移动端应用中基本上不会出现,但是在桌面端应用中是必须要支持的。 所以我们也为此付出了非常多的努力,最终使用侵入性较小的方式支持了大部分场景,并且差异化了移动端和桌面端,目前体验良好~

顺道一提的作者感受:也无怪一部分用户喜欢用 varlet + Nuxt3 来做桌面端的 C 端应用。material design 本就是支持全平台的设计系统,尤其是 material design 3,尽可能的深入了解之下才发现设计师的很多巧思和权衡。

Nuxt3 Module

为了提升 varlet 在 Nuxt3 中的使用体验,组织内的同学开发了对应的 Nuxt Module。内置了组件、指令按需自动引入的能力。未来还有更多的能力欢迎大家帮助完善,目前相对稳定,不久之后就会成为 varlet 官方首要推荐的 nuxt 集成方案。

顺便一提也是因为这个 Module,varlet 上了今年 vuejs amsterdam 会上的分享讲稿,开源工作者的小快乐总是会源于这些地方~

UnoCss / Tailwindcss 原子化框架支持

在工程中使用了原子化框架的用户总会产生一个问题,就是无法将组件的样式变量平滑的整合到工程变量中。我们为此提供了相关的预设(unocss / tailwindcss 都有对应的预设)并解决了这个问题。开发者将可以使用类似下面的方式去访问 varlet 的基础样式变量,并且 Layout 组件的响应式断点也做了一致化处理。

html 复制代码
<template> 
  <div class="text-on-primary bg-primary text-md">hello</div> 
  <div class="text-on-primary-container bg-primary-container text-lg">world</div> 
  <div class="bg-primary sm:bg-info md:bg-warning lg:bg-danger xl:bg-success">
    varlet
  </div> 
</template>

主题配色生成器

varlet 从 3.x 起开始支持 Material Design 3。在带来更强的视觉效果的同时,md3 相对于 md2 的色彩搭配难度会更高(对设计师的要求也更高)。所以谷歌官方开源了相关的色彩生成算法去解决这个问题。用户只需要通过一张产品图片,或者一个主题颜色就可以为其生成一套搭配和谐的配色。我们也因此创建了一个为 Varlet Material Design 3 服务的色彩生成器的仓库去分享给大家使用。

tips: 工具站点目前部署在 github pages,可能会受一些众所周知的原因访问不了,有需要的同学可以自己部署镜像。

结语

开源不易,希望能帮助到大家的工作、学习和生活。我们也想尽可能的多去做一些实在的事情。同时也欢迎大家参与开源共建(不仅限 varlet)。支持我们的工作可以给我们点上一个 star,我们会因此感到开心快乐。出现了使用上的问题欢迎给我们留 issue,我们会尽能力第一时间处理。

github 仓库地址: github.com/varletjs/va... 文档地址: varlet.gitee.io/varlet-ui/#...

相关推荐
华仔啊1 分钟前
jQuery 4.0 发布,IE 终于被放弃了
前端·javascript
一心赚狗粮的宇叔6 分钟前
03.Node.js依赖包补充说明及React&Node.Js项目
前端·react.js·node.js
子春一8 分钟前
Flutter for OpenHarmony:音律尺 - 基于Flutter的Web友好型节拍器开发与节奏可视化实现
前端·flutter
JarvanMo8 分钟前
150万开发者“被偷家”!这两款浓眉大眼的 VS Code 插件竟然是间谍
前端
亿元程序员9 分钟前
大佬,现在AI游戏开发教程那么多,你不搞点卖给大学生吗?
前端
未来龙皇小蓝20 分钟前
RBAC前端架构-02:集成Vue Router、Vuex和Axios实现基本认证实现
前端·vue.js·架构
空白诗25 分钟前
高级进阶 React Native 鸿蒙跨平台开发:slider 滑块组件 - 进度条与评分系统
javascript·react native·react.js
晓得迷路了34 分钟前
栗子前端技术周刊第 116 期 - 2025 JS 状态调查结果、Babel 7.29.0、Vue Router 5...
前端·javascript·vue.js
How_doyou_do36 分钟前
执行上下文、作用域、闭包 patch
javascript
叫我一声阿雷吧41 分钟前
深入理解JavaScript作用域和闭包,解决变量访问问题
开发语言·javascript·ecmascript