搜索
首页web前端js教程关于 CSS-in-JS 和实用优先 CSS (Tailwind) 的思考

Thoughts on CSS-in-JS and Utility-First CSS (Tailwind)

最近的 UI 开发任务为重新审视 CSS-in-JS 和实用优先 CSS (Tailwind) 提供了宝贵的机会。 我的日常角色很少涉及 UI 工作,因此这是一次令人耳目一新的体验,尽管有些生疏。 我的目标是对两种方法进行公正的比较,重点关注开发工作流程和工具。

Tailwind CSS

我们团队选择 Tailwind 有点自发,是出于对效率的渴望。 虽然熟悉程度各不相同,并且存在一些怀疑,但节省的时间是一个令人信服的因素。

积极方面

集成、自定义变量创建和主题开发都非常简单。 扩展或构建新主题被证明是直观的:

<code>@import "tailwindcss";
@theme {  
  --font-script: Comic-sans; // theme extension
  --color-*: initial;  // default overrides
  --color-white: #fff;
  ...
}</code>

包含基本样式,即使是像默认边距和填充删除这样简单的样式,也可以节省大量时间。 这大大简化了工作流程。

Tailwind 的目标是提供直观的体验,它在很大程度上实现了这一点。 然而,有些方面感觉不太直观。类命名约定虽然总体上很明确(例如,p 表示 padding,mb 表示 margin-bottom),但偶尔会出现不一致的情况(例如,rounded 表示 border-radius)。 这可以通过自定义主题定义来缓解:

<code>@theme { 
  --border-radius: var(--rounded);
  --border-radius-none: var(--rounded-none);
  --border-radius-full: var(--rounded-full);
  // ...etc.
  --rounded*: initial;
}</code>

总体印象

可读性和可维护性的问题比预期的要少。 虽然语法需要一段时间的调整,并且 VS Code 的 IntelliSense 偶尔会出现滞后,但即使将多个类应用于小元素,代码仍然易于管理且易于导航。

重要提示:避免过度依赖@apply。 这可能会导致“Tailwind-in-CSS”的不良结果。

服务器端渲染(SSR)

至关重要的是,Tailwind 在测试过程中没有出现 SSR 问题。 它的无缝集成是一个显着的优势。

CSS-in-JS(情感)

2024-2025 年,CS​​S-in-JS 解决方案的受欢迎程度正在下降,这主要是由于 React 等框架中服务器组件的兴起。

参见:https://www.php.cn/link/9cb4d40fce0492278209290ee3e4ae31

主要挑战

主要问题源于对 React Context API 的依赖。 在 React 应用程序中混合服务器和客户端组件可能会导致数据丢失并阻止重新渲染时正确的样式更新。 这个限制是许多 CSS-in-JS 库所固有的。

虽然存在兼容的替代方案,但根本问题仍然存在。 Joshua Comeau 的博客提供了有关此问题的精彩背景。

回顾

事后看来,向 CSS-in-JS 的转变感觉没有最初预期的那么有利。 虽然包含的开发体验(一个文件中的所有内容)最初很有吸引力,但随着时间的推移,这一优势被证明不再那么重要。

长期考虑

CSS-in-JS 导致打字和配置开销增加。 与Tailwind相比,感觉效率较低。 虽然条件道具传递提供了强大的功能和灵活性:

<code>@import "tailwindcss";
@theme {  
  --font-script: Comic-sans; // theme extension
  --color-*: initial;  // default overrides
  --color-white: #fff;
  ...
}</code>

这也会使代码理解和重构变得复杂。 过多的样式覆盖表明潜在的设计系统不一致:

<code>@theme { 
  --border-radius: var(--rounded);
  --border-radius-none: var(--rounded-none);
  --border-radius-full: var(--rounded-full);
  // ...etc.
  --rounded*: initial;
}</code>

对于新项目,我可能会避免 CSS-in-JS。

CSS 变量和主题

CSS 变量是无价的。 定义一次调色板并在组件之间重用它可以简化样式,提供与使用预定义组件变体类似的体验。

<code>const Button = styled.button`
  background: ${props => props.variant === 'primary' ? "#ddd" : "#fff"};
`;

render(
  <div>
    <button variant="primary">Primary</button>
  </div>
);</code>

后处理器和配置

后处理器(例如 PostCSS)对于优化 CSS 至关重要。 它们具有显着的优点:

  • cssnano:删除未使用的代码。
  • postcss-nested:启用类似于 Sass 的嵌套 CSS。
  • stylelint:提供 linting 功能。
  • autoprefixer:添加供应商前缀(尽管现在不太重要)。
  • postcss-import:启用 @import 语句。

(完整列表:https://www.php.cn/link/2d280461b029134123f1f1a356e176b1

在增加开销的同时,后处理器还可以改善开发人员体验和 CSS 性能。 收益往往超过初始投资。

闪电CSS

Lightning CSS(基于 Rust 的 PostCSS 替代品)提供更快的构建时间和许多相同的功能。 如果您寻求一个集成良好的解决方案,那么值得探索。

总结

CSS 格局正在迅速发展,新的工具和方法不断涌现。 我使用 Tailwind 和 CSS-in-JS 的经验非常丰富,突出了它们的优点和缺点。 RSC 对未来 CSS 工具的影响是巨大的,值得进一步考虑。

以上是关于 CSS-in-JS 和实用优先 CSS (Tailwind) 的思考的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Python和JavaScript:了解每个的优势Python和JavaScript:了解每个的优势May 06, 2025 am 12:15 AM

Python和JavaScript各有优势,选择取决于项目需求和个人偏好。1.Python易学,语法简洁,适用于数据科学和后端开发,但执行速度较慢。2.JavaScript在前端开发中无处不在,异步编程能力强,Node.js使其适用于全栈开发,但语法可能复杂且易出错。

JavaScript的核心:它是在C还是C上构建的?JavaScript的核心:它是在C还是C上构建的?May 05, 2025 am 12:07 AM

javascriptisnotbuiltoncorc; saninterpretedlanguagethatrunsonenginesoftenwritteninc.1)javascriptwasdesignedAsalightweight,解释edganguageforwebbrowsers.2)Enginesevolvedfromsimpleterterterpretpreterterterpretertestojitcompilerers,典型地提示。

JavaScript应用程序:从前端到后端JavaScript应用程序:从前端到后端May 04, 2025 am 12:12 AM

JavaScript可用于前端和后端开发。前端通过DOM操作增强用户体验,后端通过Node.js处理服务器任务。1.前端示例:改变网页文本内容。2.后端示例:创建Node.js服务器。

Python vs. JavaScript:您应该学到哪种语言?Python vs. JavaScript:您应该学到哪种语言?May 03, 2025 am 12:10 AM

选择Python还是JavaScript应基于职业发展、学习曲线和生态系统:1)职业发展:Python适合数据科学和后端开发,JavaScript适合前端和全栈开发。2)学习曲线:Python语法简洁,适合初学者;JavaScript语法灵活。3)生态系统:Python有丰富的科学计算库,JavaScript有强大的前端框架。

JavaScript框架:为现代网络开发提供动力JavaScript框架:为现代网络开发提供动力May 02, 2025 am 12:04 AM

JavaScript框架的强大之处在于简化开发、提升用户体验和应用性能。选择框架时应考虑:1.项目规模和复杂度,2.团队经验,3.生态系统和社区支持。

JavaScript,C和浏览器之间的关系JavaScript,C和浏览器之间的关系May 01, 2025 am 12:06 AM

引言我知道你可能会觉得奇怪,JavaScript、C 和浏览器之间到底有什么关系?它们之间看似毫无关联,但实际上,它们在现代网络开发中扮演着非常重要的角色。今天我们就来深入探讨一下这三者之间的紧密联系。通过这篇文章,你将了解到JavaScript如何在浏览器中运行,C 在浏览器引擎中的作用,以及它们如何共同推动网页的渲染和交互。JavaScript与浏览器的关系我们都知道,JavaScript是前端开发的核心语言,它直接在浏览器中运行,让网页变得生动有趣。你是否曾经想过,为什么JavaScr

node.js流带打字稿node.js流带打字稿Apr 30, 2025 am 08:22 AM

Node.js擅长于高效I/O,这在很大程度上要归功于流。 流媒体汇总处理数据,避免内存过载 - 大型文件,网络任务和实时应用程序的理想。将流与打字稿的类型安全结合起来创建POWE

Python vs. JavaScript:性能和效率注意事项Python vs. JavaScript:性能和效率注意事项Apr 30, 2025 am 12:08 AM

Python和JavaScript在性能和效率方面的差异主要体现在:1)Python作为解释型语言,运行速度较慢,但开发效率高,适合快速原型开发;2)JavaScript在浏览器中受限于单线程,但在Node.js中可利用多线程和异步I/O提升性能,两者在实际项目中各有优势。

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

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

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中