JavaScript库
整理一些常用且使实用的开源项目, 方便大家更高效的学习和工作.
JS 常用工具类
- lodash 一个一致性、模块化、高性能的 JavaScript 实用工具库。
- xijs 一款面向复杂业务场景的 javascript 工具库
- ramda 一个很重要的库,提供了许多有用的方法,每个 JavaScript 程序员都应该掌握这个工具
- day.js 一个轻量的处理时间和日期的 JavaScript 库,和 Moment.js 的 API 设计保持完全一样, 体积只有 2kb
- big.js 一个小型,快速的 JavaScript 库,用于任意精度的十进制算术运算
- qs 一个 url 参数转化 (parse 和 stringify)的轻量级 js 库
- decimal.js 实现 JavaScript 的任意精度的十进制类型库
表单校验
- Validator.js 一个强大的 js 表单校验库
- Validate.js 致力于提供一种验证数据的跨框架和跨语言方式的 js 库, 已通过 100%代码覆盖率的单元测试
DOM 库
- JQuery 封装了各种 dom/事件操作, 设计思想值得研究借鉴
- zepto jquery 的轻量级版本, 适合移动端操作
- fastclick 一个简单易用的库,它消除了移动端浏览器上的物理点击和触发一个 click 事件之间的 300ms 的延迟。目的就是在不干扰你目前的逻辑的同时,让你的应用感觉不到延迟,反应更加灵敏。
文件处理
- file-saver 一个在客户端保存文件的解决方案,非常适合在客户端上生成文件的 Web 应用程序
- js-xlsx 一个强大的解析和编写 excel 文件的库
网络请求
- Axios 一个基于 Promise 的 HTTP 库,可用在 Node.js 和浏览器上发起 HTTP 请求,支持所有现代浏览器,甚至包括 IE8+
- Superagent 基于 Ajax 的优化, 可以与 Node.js HTTP 客户端搭配使用
- fly.js 一个基于 promise 的 http 请求库, 可以用在 node.js, Weex, 微信小程序, 浏览器, React Native 中
动画库
- Anime.js 一个 JavaScript 动画库,可以处理 CSS 属性,单个 CSS 转换,SVG 或任何 DOM 属性以及 JavaScript 对象
- Velocity 一个高效的 Javascript 动画引擎,与 jQuery 的 $.animate() 有相同的 API, 同时还支持彩色动画、转换、循环、画架、SVG 支持和滚动等效果
- Vivus 一个零依赖的 JavaScript 动画库,可以让我们用 SVG 制作动画,使其具有被绘制的外观
- GreenSock JS 一个 JavaScript 动画库,用于创建高性能、零依赖、跨浏览器动画,已在超过 400 万个网站上使用, 并且可以在 React、Vue、Angular 项目中使用
- Scroll Reveal 零依赖,为 web 和移动浏览器提供了简单的滚动动画,以动画的方式显示滚动中的内容
- Kute.js 一个强大高性能且可扩展的原生 JavaScript 动画引擎,具有跨浏览器动画的基本功能
- Typed.js 一个轻松实现打字效果的 js 插件
- fullPage.js 一个可轻易创建全屏滚动网站的 js 滚动动画库, 兼容性无可替代
- iscroll 移动端使用的一款轻量级滚动插件
- swiper.js 一款强大的 js 跨端触摸滑动插件
- MixItUp 是用于 DOM 操作的高性能,无依赖库,使您能够使用精美的动画过滤,排序,添加和删除 DOM 元素的 js 动画库
- Lottie 一个用于 Android,iOS,Web 和 Windows 的库,用于解析使用 Bodymovin 导出为 json 的 Adobe After Effects 动画,并在移动设备和网络上呈现它们
- better-scroll 是一款重点解决移动端(已支持 PC)各种滚动场景需求的插件。它的核心是借鉴的 iscroll 的实现,它的 API 设计基本兼容 iscroll,在 iscroll 的基础上又扩展了一些 feature 以及做了一些性能优化。
鼠标/键盘相关
- KeyboardJS 一个在浏览器中使用的库(与 node.js 兼容).它使开发人员可以轻松设置键绑定和使用组合键来设置复杂的绑定.
- SortableJS 功能强大的 JavaScript 拖拽库
图形/图像处理库
- html2canvas 一个强大的使用 js 开发的浏览器网页截图工具
- dom-to-image 一个可以将任意 DOM 节点转换为用 JavaScript 编写的矢量(SVG)或光栅(PNG 或 JPEG)图像的库
- pica 一个在浏览器中调整图像大小,而不会出现像素失真,处理速度非常快的图片处理库
- Lena.js 一个轻量级的可以给你图像加各
- Compressor.js 一个使用本地 canvas.toBlob API 进行图像有损压缩的 js 库
- Fabric.js 一个易于使用的基于 HTML5 canvas 元素的图片编辑器
- merge-images 一个将多张图片合并成一张图的 js 插件
- cropperjs 一款强大的图片裁切库, 支持灵活的图片裁切方式
- Grade 一个基于图像中的前 2 种主要颜色生成互补渐变背景的库
表单表格
- x-spreadsheet 一个基于 web 的简单易用的表格插件
以上这些库不必每一样都去了解和深究, 技术都是为业务服务的, 所以我们按需使用和学习即可. 至于像 react 或者 vue 这种框架的相关生态, 笔者这里就不一一介绍了, 官网文档上都有非常详细的生态集, 感兴趣的朋友自行了解即可.