ASP.NET Core 中的捆绑和缩小静态资产 ASP.NET Core 中的捆绑和缩小静态资产 什么是捆绑和缩小 捆绑 缩小 捆绑和缩小的影响 选择捆绑和缩小策略 配置捆绑和缩小 向工作流添加文件...基于环境的捆绑和缩小 从 Gulp 使用 bundleconfig.json 手动转换捆绑和缩小工作流以使用 Gulp 运行 Gulp 任务 其他资源 参考资料 最近在B站上看到杨旭老师的 ASP.NET...什么是捆绑和缩小 捆绑和缩小是可以在 Web 应用中应用的两个不同的性能优化。 捆绑和缩小一起使用,可减少服务器的请求数并减小请求的静态资产的大小,从而提高性能。...缩小 缩小在不更改功能的情况下从代码中删除不必要的字符。 因此,请求的资产(如 CSS、图像和 JavaScript 文件)的大小大幅减小。...配置捆绑和缩小 备注 需要将 BuildBundlerMinifier NuGet 包添加到项目中使其正常工作。
Snowpack 没有从 node _ modules 文件夹下拉 npm 包,而是从 Skypack 下拉 npm 包,这是一个包含 npm 注册表的 CDN,它经过了预先优化,可以在浏览器中工作。.../node_modules/.bin/snowpack add react-dom 这不会从 npm 下载软件包,但是它会记录 Snowpack 构建所使用的软件包的版本。...这个版本带有我们期望的 Rollup 特性: 捆绑、缩小和摇树。...import ReactDOM from 'https://cdn.skypack.dev/react-dom'; Wmr 先生希望你正在编写在浏览器中运行的现代代码,这意味着如果你引入使用节点 api...看看 wmr 的源代码,它看起来像是在引擎盖下面使用了 rollup 和 terser,而且这些的缩小版本包含在 wmr 包中。
webpack 从 webpack 5 开始,现在可以配置 webpack 在生成捆绑包和模块的代码时将使用的语法。这不会转换您的代码或依赖项,只影响由 webpack 生成的“粘附”代码。...它还可以处理运行中的 Babel,并使用 Terser 以单独的针对现代和传统输出优化的设置,使捆绑包最小化。...Rollup Rollup 内部支持生成多组捆绑包作为单个版本的一部分,并默认生成现代代码。因此,可以将 Rollup 配置为通过您可能已经在使用的官方插件生成现代和传统捆绑包。...@rollup/plugin-babel 如果使用 Rollup,getBabelOutputPlugin() 方法(由 Rollup 的官方 Babel 插件提供)会转换生成的捆绑包中的代码,而不是单个源模块...Rollup 内部支持生成多组捆绑包作为单个版本的一部分,每个捆绑包都有自己的插件。
Vite根据JavaScript生态系统中最近所做的两项改进——浏览器中ES模块的可用性,以及esbuild等本机捆绑工具的编译功能,为开发者提供更加强大的支持。...Vite的核心理念是非捆绑式开发建设。 浏览器中ES模块的可用性允许您在浏览器上运行JavaScript应用程序,而无需将它们捆绑在一起。...Vite 的捆绑构建 虽然现在所有主流浏览器都支持原生ES模块,但发布一个包含诸如tree-shaking、延迟加载和通用块拆分等性能优化技术的捆绑应用程序,仍然比非捆绑应用程序会为开发者带来更好的使用体验...由于这个原因,Vite内置了一个build的配置的命令,该命令使用Rollup捆绑应用程序;我们可以根据自己的具体需求对Rollup进行自由配置。...Vite 入门基础 使用Vite构建一个应用很简单,vite build创建一个预配置的应用程序,主流前端框架React、Vue和Svelte等都可以支持。
在实际使用中Vite令人惊叹,我们可以在一两分钟内就建立一个非常高级的堆栈,并且能够轻松完成从JavaScript到TypeScript的转换以及从CSS到Sass的转换。...按照说明进行操作之后,Vite会产生一个清单文件,其中包含有关所有产生的捆绑软件的信息。并可以读取此文件的CSS和JavaScript捆绑包,生成和标签。...所有import都捆绑到中main.js,而所有动态import import('path/to/file.js')都单独捆绑。...开发人员经验 在以往的开发经验中,无论我们使用的是Grunt,Gulp,Rollup还是Webpack,这种大型复杂的项目都会花费不短的时间来调试并确保所有工具和插件都能正常运行。...Vite消除了两个工具和插件的捆绑,并新增了很多友好的默认设置,甚至可以跳过配置并直接开始工作。 如果我们有特定的需求,Vite允许我们自行设置,可以覆盖Rollup和各种Rollup插件的配置。
无论我们在开发服务器上使用 webpack、Rollup 还是 Parcel,工具都会从我们的源代码和 node_modules 文件夹中把我们的整个代码库打包在一起,通过构建过程运行这些代码,比如 Babel.../node_modules/.bin/snowpack add react-dom 这不会从 npm 下载包,但它会记录用于 Snowpack 构建所使用包的版本。...React包,而是从 es-react 中引入 React。...看了一下 wmr 的源码,似乎在引擎盖下使用了rollup和terser,wmr包中包含了这些的 minified 版本。...Snap Shot 应用的wmr捆绑包是164KB,所以它创建的捆绑包只比Vite创建的两个 JavaScript 文件的总大小小一点点。
本文将介绍如何将前端web应用程序从 Webpack 升级到 Vite。 Vite 是最新的前端开发工具,其受欢迎程度和采用率都在大幅增长。可以查看下图中来自 npm trends 的下载。...esbuild 是另一款速度惊人的 JavaScript 捆绑程序和精简程序,正吸引着网络开发人员的目光。...,Vite 使用 Rollup 作为构建工具,你可以通过 npm 安装任何 Rollup 插件,将其添加到 Vite 中: npm install –save @rollup/plugin-image...HtmlWebpackPlugin -> vite-plugin-html HtmlWebpackPlugin 可简化 HTML 文件的创建,以便为 Webpack 捆绑包提供服务。...从 Webpack 过渡到 Vite 确实需要仔细规划和测试,尤其是在考虑插件替换或重构时。但这一举措也会带来可观的回报。
react-spring 从 React Motion 继承了一些属性,例如易用性,插值和性能。...,Next.js 等公司和初创公司使用 文档:编写精巧且易于初学者使用的文档,react -spring 的文档可让您从文档中复制代码片段并测试或预览 CodeSandbox 捆绑包大小(最小):react-spring...文档:易于理解,适合初学者;您可以在文档中找到给定组件的源代码,甚至可以在 CodeSandbox 中查看它 捆绑包大小(最小):成帧器运动最小为 90.8kb!...Framer Motion 具有更大的捆绑包大小,前端培训在受欢迎程度和星级方面不如 React Spring 受欢迎,但是它的文档更容易理解,值得您在下一个 React 项目中考虑。...您可以从文档中复制给定组件的源代码 捆绑包大小(最小化):reaction-motion 19.8kb 总体而言,React-Motion 是一个适用于您的 React 应用程序的声音动画库,尤其是其几乎逼真的动画行为
参数 -W 允许在工作空间根目录中安装一个包,使其在 app、common 和 server 上全局可用。...common、app 和 server 包中。...文件 在本教程中,common 软件包将非常简单。首先,从添加新文件夹开始: src/ 文件夹,包含包的代码。...结构提醒: common/ ├─ src/ │ ├─ index.ts ├─ package.json App 依赖项 该 app 包将需要以下依赖项: react react-dom 从项目的根目录运行...JS/TS 生态系统中有许多捆绑器,如 WebPack、Parcel 或 Rollup,但我们将选择 esbuild。
在 CSR 中,「整个渲染过程发生在客户端的浏览器中」,JavaScript 捆绑包负责生成组件树和渲染用户界面。...react-dom/client 的 createRoot 方法用于「在客户端接收并高效地重构从服务器端传输的组件树」,从而完成渲染。...要将一个组件及其导入添加到 JavaScript 捆绑包中,并将其发送到客户端,从而使其具有交互性,可以在文件的顶部使用 use client 捆绑器指令。...这使得 React 可以将子组件渲染为 RSC,而无需将它们添加到客户端捆绑包中。这样可以减少客户端捆绑包的大小。 ---- 5. Suspence 另一个重要的新并发功能是 Suspense。...cache 和 fetch 的自动缓存行为允许将单个函数从全局模块导出,并在整个应用程序中重复使用它,这样可以更加高效地处理数据获取和记忆化。
当你第一次运行vite,你可能会注意到这个消息: Optimizable dependencies detected: react, react-dom Pre-bundling them to speed...这个过程有两个目的: CommonJS和UMD兼容性:在开发过程中,Vite的dev将所有代码作为本地ESM服务。因此,Vite必须首先将作为CommonJS或UMD发布的依赖项转换为ESM。...一些包将它们的ES模块构建作为许多单独的文件相互导入。例如,lodash-es有超过600个内部模块!当我们从'lodash-es'导入{debounce}时,浏览器会同时发出600多个HTTP请求!...自动依赖发现 如果没有找到现有的缓存,Vite会抓取你的源代码,并自动发现依赖项导入(即:希望从node_modules解析的“裸导入”),并使用这些发现的导入作为预绑定包的入口点。...Vite自动检测没有从node_modules解析的依赖项,并将链接的dep视为源代码。它不会尝试捆绑被链接的dep,而是会分析被链接的dep的依赖列表。
标准库”为通常需要在 Node.js 中安装软件包的常见需求提供解决方案 Deno 使用尽可能多的 Web 标准(例如:Fetch API) 使用 ECMAScript 模块导入的文件 内置测试运行器和调试器...React Server Components 将通过减少客户端捆绑包大小和缩短启动时间来改变我们构建 React 应用程序的方式。此外,它们将简化数据获取和对数据源(如数据库和文件系统)的访问。...主要变化是移至 Ivy 编译器,该编译器带来了更小的捆绑包大小和许多其他构建改进。版本 10 和 11 在今年晚些时候问世。...Snowpack 和 Vite :它们不会将代码捆绑在开发人员中,反馈循环非常快,并且会退回仅用于生产捆绑(直到增加浏览器支持)。...前端开发人员现在可以使用诸如 esbuild,Snowpack 和 Vite 之类的解决方案来更快,更简单地构建工具。 说到工具,NPM 的第 7 版提供了用于在单个存储库中处理多个软件包的工作区。
一个构建命令,它将代码与 Rollup 捆绑在一起,后者预先配置为输出用于生产的高度优化的静态资产 此外,Vite 通过其插件 API 和 JavaScript API 具有高度的扩展性,并提供全面的类型支持...现在有 Vue、 React、 Preact、 Lit Element 和正在进行的 Svelte 的官方模板 New Plugin Format and API 受到 WMR 的启发,新的插件系统扩展了...插件可以使用 rollup 兼容的钩子,以及额外的 vite 特定钩子和属性来调整 vite 专用行为(例如区分 dev 和 build 或 HMR 的自定义处理) esbuild Powered Dep...Vite 使用 Rollup 完成这项工作,而在2.0中,它现在使用 esbuild,从而使依赖性预绑定的速度提高了「10-100」倍 作为参考,React Meterial 用户界面以前需要28秒,现在需要约...,以尊重别名和 npm 依赖 URL rebasing 不管文件从哪里导入,路径都会自动重新设置 CSS code splitting Server-Side Rendering (SSR) Support
sourcemap 的作用就是映射目标代码中的位置和源码中的位置。 比如源码中的第 3 行第 5 列的代码对应着编译后的第 1 行第 10 列的代码。...和 react-dom 包就是我们需要的。...和 react-dom 包,那把这俩包复制到测试项目的 node_modules 下,就可以直接调试最初的源码了么?...不打包 react 和 react-dom 这俩包不就行了。不经过 webpack 打包,那就没有 webpack 产生的 sourcemap,不就一次就映射到 React 最初的源码了么。...修改 webpack 配置,在 externals 下添加 react 和 react-dom 包对应的全局变量: 然后把 react.development.js 和 react-dom.development.js
02)、捆绑工具 有几种流行的工具可用于捆绑 JavaScript 文件,每种工具都有其独特的特性和优势。...它具有强大的插件生态系统,允许你根据需要扩展其功能。 Rollup:Rollup 是另一个流行的 JavaScript 模块打包器,专注于简单性和性能。...`; } // math.js export function calculate(x, y) { return x * y; } 使用 Webpack 或 Rollup 等捆绑工具,你可以将这些文件组合成一个捆绑文件...有几个工具可以帮助实现代码拆分,例如 Webpack 和 React.lazy: Webpack:这个流行的捆绑器提供对代码拆分的内置支持。...从最小化文件大小和减少网络请求到利用缓存和异步加载,这些方法都可以对你网站的加载时间产生重大影响。
02)、捆绑工具 有几种流行的工具可用于捆绑 JavaScript 文件,每种工具都有其独特的特性和优势。...它具有强大的插件生态系统,允许你根据需要扩展其功能。 Rollup:Rollup 是另一个流行的 JavaScript 模块打包器,专注于简单性和性能。...`; } // math.js export function calculate(x, y) { return x * y; } 使用 Webpack 或 Rollup 等捆绑工具,你可以将这些文件组合成一个捆绑文件...有几个工具可以帮助实现代码拆分,例如 Webpack 和 React.lazy: Webpack:这个流行的捆绑器提供对代码拆分的内置支持。...从最小化文件大小和减少网络请求到利用缓存和异步加载,这些方法都可以对你网站的加载时间产生重大影响。 我希望你能发现本指南内容丰富且有用。
例如已经基本上将框架编译掉的Svelte或是Snowpack,这些工具能够利用现代JavaScript功能(例如ES模块)来提供更平稳,更快速的开发体验,几乎不需要配置,也不需要依赖于太多已安装软件包。...通过使用它,我们可以快速启动Vue或React项目,而无需再使用Vue CLI或Create React App。高效、快速就是它的代名词。...最新的版本中还增加了 optimize 命令的支持。...开发人员经验 在以往的开发经验中,无论我们使用的是Grunt,Gulp,Rollup还是Webpack,这种大型复杂的项目都会花费不短的时间来调试并确保所有工具和插件都能正常运行。...Vite消除了两个工具和插件的捆绑,并新增了很多友好的默认设置,甚至可以跳过配置并直接开始工作。 如果我们有特定的需求,Vite允许我们自行设置,可以覆盖Rollup和各种Rollup插件的配置。
包体的大小 webpack和rollup对比 webpack算是使用程序员使用最多的打包工具,面试中往往会问到webpack的相关问题,而rollup被问到的要少很多。...但当我们做前端应用时,性能分析往往要求更小的库,所以rollup更符合开发库的要求。 这次算是一个打包的实验,我们使用两个工具都对这个项目打一次包。..." ], // 将react和react-dom移动到该配置中,兼容依赖 "peerDependencies": { "react": "^17.0.1", "react-dom...npm pack 对项目打包后,命令行输出压缩包的详细信息。 ?...npm publish 然后就会收到邮件,你的包已经发布成功。
领取专属 10元无门槛券
手把手带您无忧上云