前端高效开发必备的 js 库梳理
之前有很多人问学好前端须要学习哪些 js 库, 支流框架应该学 vue 还是 react ? 针对这些问题, 笔者来说说本人的认识和学习总结.
首先我感觉在学习任何常识之前必须要有一个明确的学习指标, 晓得本人为什么要学它, 而不是看网上说的一股脑的给你灌输各种常识, 让你学习各种库, 从而一直的制作大家的焦虑感.
前端 因为入行门槛低, 更新换代很快, 每年都会有大量新的框架和库呈现, 也有大量库被淘汰(比方 JQuery
, 然而学习它的设计思维很有必要). 所以咱们大可不必放心, 放弃本人的学习步调, 按需学习即可. 比如说你对挪动端比拟感兴趣, 工作中也刚好波及到一些技术的利用, 那么我能够专门钻研挪动端相干的技术和框架, 又或者你对企业后盾 / 中台产品感兴趣, 比拟喜爱开发 PC 端我的项目, 那么咱们能够专门钻研这种类型的 js 库或者框架, 接下来笔者也是依照不同前端业务的需要, 来整顿一份能疾速利用到工作中的 js 库, 以进步大家的开发效率.
js 常用工具类
- lodash 一个一致性、模块化、高性能的 JavaScript 实用工具库。
- ramda 一个很重要的库,提供了许多有用的办法,每个 JavaScript 程序员都应该把握这个工具
- day.js 一个轻量的解决工夫和日期的 JavaScript 库,和 Moment.js 的 API 设计放弃齐全一样, 体积只有 2kb
- big.js 一个小型,疾速的 JavaScript 库,用于任意精度的十进制算术运算
- qs 一个 url 参数转化 (parse 和 stringify)的轻量级 js 库
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 挪动端应用的一款轻量级滚动插件
鼠标 / 键盘相干
- KeyboardJS 一个在浏览器中应用的库(与 node.js 兼容). 它使开发人员能够轻松设置键绑定和应用组合键来设置简单的绑定.
- SortableJS 功能强大的 JavaScript 拖拽库
图形 / 图像处理库
- html2canvas 一个弱小的应用 js 开发的浏览器网页截图工具
- dom-to-image 一个能够将任意 DOM 节点转换为用 JavaScript 编写的矢量(SVG)或光栅(PNG 或 JPEG)图像的库
- pica 一个在浏览器中调整图像大小,而不会呈现像素失真,处理速度十分快的图片解决库
- Lena.js 一个轻量级的能够给你图像加各种滤镜的 js 库
- Compressor.js 一个应用本地 canvas.toBlob API 进行图像有损压缩的 js 库
- Fabric.js 一个易于应用的基于 HTML5 canvas 元素的图片编辑器
- merge-images 一个将多张图片合并成一张图的 js 插件
- cropperjs 一款弱小的图片裁切库, 反对灵便的图片裁切形式
- Grade 一个基于图像中的前 2 种次要色彩生成互补突变背景的库