搜索
首页web前端css教程WebPack和Vue如何将页面大小提高1,500%

本文以幽默的口吻讲述了作者如何使用Webpack和Vue大幅增加CSS文件大小的故事,并最终通过改进方法解决了这个问题。文章并非鼓励增加页面大小,而是以反讽的方式展现了在使用Bulma框架和Vue CLI过程中遇到的问题及解决方法。

How to Increase Your Page Size by 1,500% with webpack and Vue

免责声明: 本文带有讽刺意味。作者并非认为自己比读者高明,也不认为增加网页大小是好事。

许多文章都教你如何减小页面大小:优化图片、移除冗余CSS规则等等。作者以沃尔玛为例,指出其页面大小的缩减。

JavaScript优化建议:

?️ 删除旧的和重复的依赖 ? 将大型依赖替换为小型依赖 ? 检查是否过度polyfill ? 清理A/B测试配置 ✂️ 代码分割!

沃尔玛在其网站上进行了此操作。JS包缩小了69%。交互时间缩短了28%。

然而,鲜有文章教你如何增加页面大小。作者尝试寻找相关资料,却只找到一篇关于增大字体大小的文章。

意外的“增重”

为什么要增加页面大小呢?这对于低带宽用户来说不是一件好事吗?作者给出了一些看似合理的,实则略显滑稽的理由:

  1. 你拥有千兆带宽,而且住在田纳西州(暗示网络条件优越)。
  2. 浏览器会缓存,你只需要下载一次网站。
  3. 你不在乎是否有人访问你的网站,因为你“工作是为了生活,而不是为了工作而生活”。

如果你认同这些理由,作者将展示如何将CSS大小增加1500%——只需一个简单的Webpack技巧。

奇妙的技巧

作者在将项目重构到Bulma CSS框架时发现了这个问题。最初的代码混乱不堪,Sass代码如同“囤积者”节目中的场景。

Bulma包含模态框等功能,作者之前使用的是第三方Vue组件。它还有一个汉堡菜单,因为这是众所周知的成功网站必备元素。

重构完成后,作者发现CSS大小显著增加。最初的手工编写代码只有30KB(gzip压缩后),重构后达到了260KB。Vue CLI也对此发出了警告,但作者忽略了。

作者将项目部署到生产环境,并在Twitter上宣布了这一“成就”。Bulma的创建者Jeremy Thomas对此做出了回应,指出CSS大小增加是因为存在大量重复样式。

问题所在

作者承认自己对CSS和Sass了解不多。在使用Vue CLI项目时,作者创建了一个src/styles文件夹,并在其中放置了一个bulma-but-not-all-of-bulma-only-some-of-it.scss文件,该文件导入部分Bulma组件。然后,将该文件导入到自定义Sass文件site.scss中。

为了在每个组件中使用这些样式,作者使用了Sarah Drasner的一篇博客文章中的方法,通过修改vue.config.js文件来修改Webpack构建过程。

作者没有理解的是,这种方法会将Sass导入到每个Vue组件中。这导致了大量重复样式,因为Vue会为每个组件添加data-v-属性。

Vue如何处理scoped

Vue允许将样式作用域限制在组件内,通过动态插入data-属性实现。如果在组件中导入包含样式的Sass文件,Vue(通过Webpack)会将这些样式与动态data-属性一起命名空间化。

变量共享问题

你无法在一个组件中定义Sass变量,并在另一个组件中引用它。

使用Bulma和Vue的最佳实践

为了解决这个问题,作者建议使用三个文件:variables.scss(导入Bulma变量)、bulma-custom.scss(导入Bulma组件)和site.scss(定义全局样式)。将site.scss导入到main.js文件中,并将variables.scss添加到vue.config.js文件中。

这样,Bulma就全局可用,并且可以在每个组件中访问所有Bulma变量。CSS大小最终显著减小。

改进后的方案

作者还提交了一个PR到Bulma文档,介绍了如何在Vue CLI项目中自定义Bulma。

以上是WebPack和Vue如何将页面大小提高1,500%的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
锚定位只是不关心来源订单锚定位只是不关心来源订单Apr 29, 2025 am 09:37 AM

锚定定位避开HTML源顺序的事实是如此css-y,因为它在内容和演示文稿之间的另一个关注点分离。

保证金是什么:40px 100px 120px 80px表示?保证金是什么:40px 100px 120px 80px表示?Apr 28, 2025 pm 05:31 PM

文章讨论了CSS保证金属性,特别是“保证金:40px 100px 120px 80px”,其应用程序以及对网页布局的影响。

什么是不同的CSS边框特性?什么是不同的CSS边框特性?Apr 28, 2025 pm 05:30 PM

本文讨论了CSS边境属性,重点是自定义,最佳实践和响应能力。主要论点:边境 - 拉迪乌斯(Border-Radius)对响应式设计最有效。

什么是CSS背景,列出属性?什么是CSS背景,列出属性?Apr 28, 2025 pm 05:29 PM

本文讨论了CSS背景属性,它们在增强网站设计方面的用途以及避免的常见错误。重点是使用背景大小的响应式设计。

什么是CSS HSL颜色?什么是CSS HSL颜色?Apr 28, 2025 pm 05:28 PM

文章讨论了CSS HSL颜色,其在网络设计中的使用以及比RGB的优势。主要重点是通过直观的颜色操纵来增强设计和可访问性。

我们如何在CSS中添加评论?我们如何在CSS中添加评论?Apr 28, 2025 pm 05:27 PM

本文讨论了CSS中评论的使用,详细介绍了单线和多行评论语法。它认为注释可以增强代码可读性,可维护性和协作,但如果无法正确管理,可能会影响网站性能。

什么是CSS选择器?什么是CSS选择器?Apr 28, 2025 pm 05:26 PM

本文讨论了CSS选择器,其类型和用于造型HTML元素的用法。它比较ID和类选择器,并与复杂的选择器解决性能问题。

哪种类型的CSS持有最高优先级?哪种类型的CSS持有最高优先级?Apr 28, 2025 pm 05:25 PM

本文讨论了CSS优先级,重点是具有最高特异性的内联风格。它解释了特异性级别,覆盖方法和用于管理CSS冲突的工具。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能