NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

Vant 1.0 正式发布:轻量、可靠的移动端 Vue 组件库

  • 2020-03-11
  • 本文字数:1419 字

    阅读完需:约 5 分钟

Vant 1.0 正式发布:轻量、可靠的移动端 Vue 组件库

Vant 是有赞前端团队维护的移动端 Vue 组件库,提供了一整套 UI 基础组件和业务组件。通过 Vant 可以快速搭建出风格统一的页面,提升开发效率。

一、关于 Vant 1.0

距离 Vant 首次发布刚好过去了半年时间,在这半年时间里 Vant 团队广泛吸纳社区的反馈和建议,持续对组件进行打磨、优化,使得 Vant 逐渐成长为一个轻量、可靠的移动端 Vue 组件库。


在这个时间点上我们决定发布 Vant 的 1.0 正式版,希望未来有更多小伙伴能够参与到 Vant 的开发和使用中来。


GitHub 地址:github.com/youzan/vant(点击「阅读原文」直达)

二、现有组件

三、开发理念

轻量化

作为移动端组件库, Vant 一直将轻量化作为核心开发理念。为了平衡日益丰富的功能和轻量化之间的矛盾关系,我们尝试了很多的优化方式,包括支持组件按需加载、公共模块复用、组件编译流程优化等。


在应用一系列的优化手段之后,目前 Vant 的组件平均体积仅有 8.8KB,Uglify + Gzip 后约 1KB。作为对比, mint-ui 的组件平均体积为 15.2KB,某些组件库的组件平均体积甚至在 25KB 以上。


Vant 之所以能保持如此小的组件体积,主要归功于我们独特的组件编译方式。目前主流的组件编译方式是通过 webpack 搭配 vue-loader 对每个组件进行编译,为每个组件生成一个打包后 JS 文件。这样的做法会产生大量的冗余代码,比如 webpack 内置的模块化代码、vue-loader 内置的 normalize 函数、重复引入的 babel helper 等等,而我们不希望在组件的编译结果中引入这些冗余代码。


一开始我们尝试通过使用 rollup 和 rollup-plugin-vue 去解决上述的问题,但很快我们就发现了更为直接的方式,即通过官方提供的 vue-template-compiler 和 babel 对组件进行编译,这样的方式简单纯粹,编译出的代码非常干净,细节在此不做赘述,有兴趣的同学可以看下 Vant 中构建部分的源码。

快速迭代

另外一个很重要的理念是快速迭代。有赞前端团队几十个工程师每天都在用的就是现在你看到的 GitHub 上这个版本,我们并没有一个所谓的“内部版”。同时,出于对自己名誉的珍视,我们不是简单地把它开源了事,而是把它当做一款技术产品去维护,不单单自己用的爽,也要让别人好用,因此我们会保持对社区需求的快速响应、对 bug 及时跟进并修复。


迄今为止项目 commit 总数超过 1600 次,解决 issue 300 个,合并 Pull Request 400 个,发布 90 次,基本上保持了一周 1 ~ 2 次的发布节奏。这里面包含了很多社区开发者的付出,感谢他们对 Vant 作出的贡献~ 在未来我们也会继续保持这样的开发节奏,为社区输出更好的开源产品。

生态化

除了提供组件以外,我们也在为丰富 Vant 的开发生态做很多尝试,希望能覆盖各个场景下的开发需求,为大家提供便利。下面是我们现有的一些生态或能力:


  • 基于 vue-cli 的脚手架 vue-cli-template-vant

  • 支持 nuxt 服务器端渲染

  • 支持 Typescript 类型检测

  • 支持 i18n 多语言定制

  • 支持通过 postcss 插件进行主题定制

  • 官方 Demo 仓库 - vant-demo

  • 基于相同视觉规范的小程序组件库 - zanui-weapp

  • 开源社区的移动商城示例项目 - vant–mobile-mall


在生态化方面我们还有很多需要补齐的方面,比如提供对 rem 的支持、vscode 代码提示插件等,这些将会是我们 18 年尝试的方向。

四、最后

开源项目的进步离不开社区的贡献,非常感谢过去对 Vant 提出 PR 和意见的所有人,尤其感谢社区 @chuangbo、@qianzhaoyan、@GeoffZhu 等同学的付出。希望未来能有更多的同学加入到 Vant 的开发中来。如果你对有赞的前端团队感兴趣,也欢迎加入我们一起玩耍~


2020-03-11 22:19621

评论

发布
暂无评论
发现更多内容

NGINX 开源社区捉虫征集令

NGINX开源社区

打造五层轻量监控体系

穿过生命散发芬芳

监控体系 12月月更

架构实战 模块一:作业

Geek_6c89ef

行话|入局「软件定义汽车」,你真的准备好了吗?

极狐GitLab

DevOps 汽车软件安全 软件定义汽车 极狐GitLab 汽车软件开发

一块钱能做什么?

白洞计划

LinkedIn创始人对话 OpenAI CEO :创业公司的机会—价值中间层

B Impact

网络安全之反序列化漏洞分析

网络安全学海

黑客 网络安全 信息安全 渗透测试 漏洞挖掘

高效!启科量子线路模拟器QuSprout与AWS HPC集成,赋能量子计算

启科量子开发者官方号

量子计算

CorelDRAW软件2023最新版本更新下载

茶色酒

CorelDraw2023 CorelDraw

React源码分析6-hooks源码

goClient1992

React

读者回信:为什么畅捷通可能会迎来戴维斯双杀?

B Impact

「虚拟社交」爆火,资深玩家「当道」

融云 RongCloud

社交 虚拟形象

Spring AOP在项目中的典型应用场景

江南一点雨

Java spring aop springboot

建立数据地图,让数据资产“活”起来

数造万象

数据治理:数据访问也需要治理!

用友BIP

《媒体大数据分类分级指南》团体标准正式发布,易观分析参与编制

易观分析

大数据 媒体

SeaweedFS 高可用方案最佳实践

冰心的小屋

分布式文件系统 SeaweedFS

Verilog 数据类型

智趣匠

Verilog Verilog数据类型 Verilog语法

架构学习笔记1:什么是架构设计?

生活需要激情

架构训练营10期

AWS AMAZON BRAKET与量子计算

启科量子开发者官方号

mysql数据库之schema与数据类型优化

@下一站

程序设计 代码优化 MySQL优化 11月日更 11月月更

设计原则 — S 单一职责原则

Lemoon Can

面向对象设计原则 设计原则

BSN-DDC基础网络DDC SDK详细设计(八):示例

BSN研习社

BSN-DDC

【零代码】6步轻松完成 Kafka 实时数据接入 MatrixDB

YMatrix 超融合数据库

json kafka 零代码 超融合数据库 YMatrix

金融行业业财融合实践:5A全面预算管理,赋能金融企业高质量发展

B Impact

CleanMyMac4.12Crack版本弹出密码如何解决教程

茶色酒

CleanMyMac CleanMyMac X CleanMyMac X2023

精准管控 | AIRIOT数字油库智能化解决方案

AIRIOT

物联网 数字油库

FLStudio21水果体验版更新下载及功能介绍

茶色酒

flstudio FLStudio21

Spark RDD分区数与分区器源码解析

数新网络官方账号

spark

有奖征文 | 当我们谈操作系统时,我们在谈什么?

腾源会

开源 操作系统 opencloudOS

如何打造用户“上瘾”的产品?

产品海豚湾

产品经理 用户体验 产品运营 用户思维 12月月更

Vant 1.0 正式发布:轻量、可靠的移动端 Vue 组件库_文化 & 方法_有赞技术_InfoQ精选文章