前端框架的数据驱动

这篇具有很好参考价值的文章主要介绍了前端框架的数据驱动。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

开篇 :让 Vite 助力你的前端工程化之路

当下,在项目开发的过程中,前端工程师们越来越离不开构建工具了,可以说构建工具已经成为了前端工程项目的标配。

不过,如今的前端构建工具可谓乱花渐欲迷人眼,有远古时代的browserifygrunt,有传统的WebpackRollupParcel,也有现代的EsbuildVite 等等,不仅种类繁多,更新也很快。

于是,很多朋友会问我,到底哪个构建工具更好用、值得学。事实上,无论工具层面如何更新,它们解决的核心问题,即前端工程的痛点是不变的。因此,想要知道哪个工具更好用,就要看它解决前端工程痛点的效果。

那么,前端工程都有哪些痛点呢?

首先是前端的模块化需求。我们知道,业界的模块标准非常多,包括 ESM、CommonJS、AMD 和 CMD 等等。前端工程一方面需要落实这些模块规范,保证模块正常加载。另一方面需要兼容不同的模块规范,以适应不同的执行环境。

其次是兼容浏览器,编译高级语法。由于浏览器的实现规范所限,只要高级语言/语法(TypeScript、 JSX 等)想要在浏览器中正常运行,就必须被转化为浏览器可以理解的形式。这都需要工具链层面的支持,而且这个需求会一直存在。

再者是线上代码的质量问题。和开发阶段的考虑侧重点不同,生产环境中,我们不仅要考虑代码的安全性兼容性问题,保证线上代码的正常运行,也需要考虑代码运行时的性能问题。由于浏览器的版本众多,代码兼容性和安全策略各不相同,线上代码的质量问题也将是前端工程中长期存在的一个痛点。

同时,开发效率也不容忽视。 我们知道,项目的冷启动/二次启动时间热更新时间都可能严重影响开发效率,尤其是当项目越来越庞大的时候。因此,提高项目的启动速度和热更新速度也是前端工程的重要需求。

那么,前端构建工具是如何解决以上问题的呢?

  • 模块化方面,提供模块加载方案,并兼容不同的模块规范。
  • 语法转译方面,配合 SassTSCBabel 等前端工具链,完成高级语法的转译功能,同时对于静态资源也能进行处理,使之能作为一个模块正常加载。
  • 产物质量方面,在生产环境中,配合 Terser等压缩工具进行代码压缩和混淆,通过 Tree Shaking 删除未使用的代码,提供对于低版本浏览器的语法降级处理等等。
  • 开发效率方面,构建工具本身通过各种方式来进行性能优化,包括使用原生语言 Go/Rustno-bundle等等思路,提高项目的启动性能和热更新的速度。

为什么 Vite 是当前最高效的构建工具?

现在,让我们回到一开始提出的问题,到底哪个工具更好用?或者说,哪个工具解决前端工程痛点的效果更好?

The State of JavaScript Survey 最近的调查结果中显示, Vite 在全球开发者中的满意度超过 98%,已经被用到了SvelteKitAstro这些大型框架中,成为当下最受瞩目的前端构建工具。我也最推荐你使用它。为什么是 Vite 呢?我们可以根据上面说的四个维度来审视它。

首先是开发效率。传统构建工具普遍的缺点就是太慢了,与之相比,Vite 能将项目的启动性能提升一个量级,并且达到毫秒级的瞬间热更新效果。

就拿 Webpack 来说,我在工作中发现,一般的项目使用 Webpack 之后,启动花个几分钟都是很常见的事情,热更新也经常需要等待十秒以上。这主要是因为:

  • 项目冷启动时必须递归打包整个项目的依赖树
  • JavaScript 语言本身的性能限制,导致构建性能遇到瓶颈,直接影响开发效率

这样一来,代码改动后不能立马看到效果,自然开发体验也越来越差。而其中,最占用时间的就是代码打包和文件编译。

而 Vite 很好地解决了这些问题。一方面,Vite 在开发阶段基于浏览器原生 ESM 的支持实现了no-bundle服务,另一方面借助 Esbuild 超快的编译速度来做第三方库构建和 TS/JSX 语法编译,从而能够有效提高开发效率。

除了开发效率,在其他三个维度上, Vite 也表现不俗。

  • 模块化方面,Vite 基于浏览器原生 ESM 的支持实现模块加载,并且无论是开发环境还是生产环境,都可以将其他格式的产物(如 CommonJS)转换为 ESM。
  • 语法转译方面,Vite 内置了对 TypeScript、JSX、Sass 等高级语法的支持,也能够加载各种各样的静态资源,如图片、Worker 等等。
  • 产物质量方面,Vite 基于成熟的打包工具 Rollup 实现生产环境打包,同时可以配合TerserBabel等工具链,可以极大程度保证构建产物的质量。

因此,如果你想要学习一个前端构建工具,Vite 将会是你当下一个最好的选择。它不仅解决了传统构建工具的开发效率问题,而且具备一个优秀构建工具的各项要素,还经历了社区大规模的验证与落地。

如何才能学好 Vite ?

不过,很多人在学习和应用 Vite 的过程中总会遇到各种各样的问题。

比如说,很多 Vite 学习资料既不系统,也不深入。绝大多数的文章只能教会我们如何搭建一个简单的脚手架项目,甚至代码都不一定正确。

即使通过资料学完了 Vite 的相关知识,但因为对 Vite 的生态了解不够,遇到实际问题的时候依然不知道要使用哪些插件或者解决方案。

  • 第三方库里面含有 CommonJS 代码导致报错了怎么办?
  • 想在开发过程中进行 Eslint 代码规范检查怎么办?
  • 生产环境打包项目后,如何产出构建产物分析报告?
  • 如果要兼容不支持原生 ESM 的浏览器,怎么办?

而且,如果你对 Vite 底层使用的构建引擎 Esbuild 和 Rollup 不够熟悉,遇到一些需要定制的场景,往往也会捉襟见肘。

  • 写一个 Esbuild 插件来处理一下问题依赖
  • 对于 Rollup 打包产物进行自定义拆包,解决实际场景中经常出现的循环依赖问题
  • 使用 Esbuild 的代码转译和压缩功能会出现哪些兼容性问题?如何解决?

当然,作为一个构建工具,Vite 的难点不仅在于它本身的灵活性,也包含了诸如Babelcore-js 等诸多前端工具链的集成和应用。

  • @babel/preset-envuseBuiltIns 属性各个取值有哪些区别?
  • @babel/polyfill@babel/runtime-corejs 有什么区别?
  • @babel/plugin-transform-runtime@babel/preset-envuseBuiltIn 相比有什么优化?
  • core-js 的作用是什么?其产物有哪些版本?core-jscore-js-pure 有什么区别?

此外,由于构建工具(不仅包括 Vite,也包括底层引擎 Rollup)的源码晦涩难懂,涉及大量的基础工具库,导致很多人对构建工具原理的理解只浮于表面,很难更进一步。

作为一名深耕在一线的前端工程师,我的日常工作就是跟各种构建工具打交道,在公司中诸多的业务项目中落地了 Vite,有丰富的 Vite 实战经验和源码阅读经验,也给 Vite 仓库贡献过一些代码。因此,我也非常乐意将自己在 Vite 方面的实战经验与学习方法通过小册系统性地分享给大家。

那么, Vite 该如何学习呢?我按照循序渐进、可实操、可延伸的三个原则,由浅入深设计课程内容,提供大量的实战场景和案例,同时尽可能给大家提供解决问题的方法和视角,让大家学完课程后能做到举一反三。具体来说,我将课程设计为 5 个模块。

在基础使用篇中,我将与你从 0 开始实现 Vite 项目初始化,接入各种现代化的 CSS 方案,集成 Eslint、Styelint、Commonlint 等一系列 Lint 工具链,处理各种形式的静态资源,掌握 Vite 预编译的各种使用技巧,最终让你能独立搭建一个相对完整的脚手架工程。

在双引擎篇中,我们会学习 Vite 的双引擎架构, Esbuild 和 Rollup 相关的内容,包括它们的基本使用和插件开发,掌握最小必要知识,为后续的高级应用作铺垫。

而高级应用篇, 我们将学习 Vite 的各种高级用法和构建性能优化手段,学会如何编写一个完整的 Vite 插件,熟练进行生产环境拆包,使用 Vite 搭建复杂的 SSR 工程,实现基于模块联邦的跨应用模块共享架构。不管是项目性能优化技巧,还是对前端底层标准和规范的理解,你都会从这一模块得到不少提升。

接下来,我们将一起剖析 Vite 的核心源码,理解诸如JITProxy ModuleModule GraphHMR BoundaryPlugin Container 等源码中重要概念的作用及底层实现,一步步教你学会阅读 Vite 的源码,将如下架构图中的关键环节各个击破,学透 Vite 实现原理。

最后是手写实战篇。 首先,我们会手写 Vite 的开发时 no-bundle 服务,也就是开发环境下基于浏览器原生 ESM 的 Dev Server。然后,我也会带你一步步完成一个生产环境打包工具(Bundler),从 AST 解析的功能开始,完成代码的词法分析(tokenize)和语义分析(parse),实现模块依赖图和作用域链的搭建,并完成 Tree Shaking、循环依赖检测及 Bundle 代码生成,最终实现一个类似 Rollup 的 Bundler。

可以看到,我们在课程中非常重视上手实战。课程的代码全部会上传至 Github 仓库(仓库地址),基本上每一节内容都有能 run 起来的代码案例。尤其在最后一章,为了让你理解构建工具的底层原理,我会带你一步步搭建一个简单的构建工具,进行上千行代码的手写实战,做到真正的代码可实操。

-vite)),基本上每一节内容都有能 run 起来的代码案例。尤其在最后一章,为了让你理解构建工具的底层原理,我会带你一步步搭建一个简单的构建工具,进行上千行代码的手写实战,做到真正的代码可实操。

最后,我希望我们能一起深入 Vite 的实战要点和实现原理 ,领略前端工程化构建领域的底层风光,真正实现 Vite 从入门到进阶!文章来源地址https://www.toymoban.com/news/detail-514269.html

到了这里,关于前端框架的数据驱动的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 微信小程序底层框架实现原理:开篇-双线程架构

    介绍章节我们聊了一下“小程序”的一些概念和发展历程,并且拓展了一下思路。我们从本章节开始讲解小程序的架构。 本章节分解如下: 小程序的双线程架构设计。 双线程对比单线程的优势在哪里。 传统h5开发环境有什么弊端。 Native层在双线程架构中起到怎样的作用。

    2024年03月23日
    浏览(38)
  • 前端数据安全:保护你的应用不被黑客入侵

    在当今数字化时代,前端开发者的一个主要职责是确保应用程序中的数据安全。黑客们总是在寻找机会来窃取敏感信息,所以作为前端开发者,我们需要采取一些措施来保护用户数据。本文将介绍一些前端数据安全的基本原则和技术。 HTTPS 是一种加密通信协议,可以确保数据

    2024年02月11日
    浏览(35)
  • 让AIGC成为你的智能外脑,助力你的工作和生活

    在当前的科技浪潮中,人工智能技术正在以前所未有的速度改变着我们的生活和工作方式。其中,AIGC技术以其强大的潜力和广泛的应用前景,正在引领着这场革命。 AIGC技术是一种基于人工智能的生成式技术,它可以通过学习和模仿,生成新的内容。这种技术在新闻媒体、广

    2024年02月04日
    浏览(29)
  • 「AIGC」如何助力个人创意,打造属于你的独特时代?

    当今时代,人工智能(AI)不仅仅是科幻电影中的概念,也已经广泛应用于各行各业。其中,AI在创意领域的应用越来越受到关注。从AI生成的诗歌、绘画、音乐等作品的出现,到AI辅助创意产生的创意设计、广告营销等领域的应用,都为我们展示了AI在创意领域的无限可能。 AI生

    2024年02月11日
    浏览(45)
  • 自动化测试框架之关键字驱动和数据驱动

    文章架构 1.什么是驱动 2.什么是数据驱动 3.数据驱动和驱动的关系 4.数据驱动和驱动结合进行测试的实施流程 5.案例 1.什么是驱动? 驱动是自动化测试框架设计的核心内容,可以解决代码冗余、可读性、维护性、代码复用性等问题。 比如,

    2024年02月14日
    浏览(36)
  • 数据知识驱动的城市作战元宇宙建模框架

    源自:指挥与控制学报 作者:郑文博   李强  刘文礼  费爱国  王飞跃 图 1 平行智能与元宇宙 图2 数据知识驱动的城市作战元宇宙建模框架 图3 基于新型生成式对抗网络的生成与扩充技术 图4 受人类视觉系统启发的生成式对抗网络 图5 元宇宙城市作战知识图谱构建 图6 基于

    2024年02月03日
    浏览(26)
  • 扬帆未来,成就架构之路:十本书籍助力你的架构师梦想 | 文末送书

    相信大家都对未来的职业发展有着憧憬和规划,要做架构师、要做技术总监、要做CTO。对于如何实现自己的职业规划也都信心满满,努力工作、好好学习、不断提升自己。 当涉及未来职业发展时,我们都怀揣着远大的目标和野心。对许多人而言,成为一名优秀的架构师、技术

    2024年02月05日
    浏览(32)
  • 数据驱动 vs 关键字驱动:对搭建UI自动化测试框架的探索

    UI自动化测试用例剖析 让我们先从分析一端自动化测试案例的代码开始我们的旅程。以下是我之前写的一个自动化测试的小Demo。这个Demo基于Selenium与Java。由于现在Selenium在自动化测试的统治地位,并且随着Selenium 4的即将发布,在未来很长的一段时间里这种统治地位应该还会

    2024年02月19日
    浏览(36)
  • 【软件测试】UI自动化框架,数据驱动 vs 关键字驱动怎么选

    让我们先从分析一端自动化测试案例的代码开始我们的旅程。以下是我之前写的一个自动化测试的小Demo。这个Demo 基于Selenium与Java 。 自动化测试小Demo 它要测试的东西其实是要看一下百度搜索能不能返回兴业银行的官网。我们分析一下这段代码都包含些什么东西。 第一,这

    2024年02月13日
    浏览(47)
  • UI 自动化测试框架:PO 模式+数据驱动

    PO(PageObject)设计模式将某个页面的所有元素对象定位和对元素对象的操作封装成一个 Page 类,并以页面为单位来写测试用例,实现页面对象和测试用例的分离。 PO 模式的设计思想与面向对象相似,能让测试代码变得可读性更好,可维护性高,复用性高。 PO 模式可以把一个

    2024年02月06日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包