目录
Tailwind CSS
积极方面
总体印象
服务器端渲染(SSR)
CSS-in-JS(情感)
主要挑战
回顾
长期考虑
CSS 变量和主题
后处理器和配置
闪电CSS
总结
首页 web前端 js教程 关于 CSS-in-JS 和实用优先 CSS (Tailwind) 的思考

关于 CSS-in-JS 和实用优先 CSS (Tailwind) 的思考

Jan 26, 2025 am 08:33 AM

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

热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

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

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

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1657
14
CakePHP 教程
1415
52
Laravel 教程
1309
25
PHP教程
1257
29
C# 教程
1229
24
神秘的JavaScript:它的作用以及为什么重要 神秘的JavaScript:它的作用以及为什么重要 Apr 09, 2025 am 12:07 AM

JavaScript是现代Web开发的基石,它的主要功能包括事件驱动编程、动态内容生成和异步编程。1)事件驱动编程允许网页根据用户操作动态变化。2)动态内容生成使得页面内容可以根据条件调整。3)异步编程确保用户界面不被阻塞。JavaScript广泛应用于网页交互、单页面应用和服务器端开发,极大地提升了用户体验和跨平台开发的灵活性。

JavaScript的演变:当前的趋势和未来前景 JavaScript的演变:当前的趋势和未来前景 Apr 10, 2025 am 09:33 AM

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。

JavaScript引擎:比较实施 JavaScript引擎:比较实施 Apr 13, 2025 am 12:05 AM

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

JavaScript:探索网络语言的多功能性 JavaScript:探索网络语言的多功能性 Apr 11, 2025 am 12:01 AM

JavaScript是现代Web开发的核心语言,因其多样性和灵活性而广泛应用。1)前端开发:通过DOM操作和现代框架(如React、Vue.js、Angular)构建动态网页和单页面应用。2)服务器端开发:Node.js利用非阻塞I/O模型处理高并发和实时应用。3)移动和桌面应用开发:通过ReactNative和Electron实现跨平台开发,提高开发效率。

Python vs. JavaScript:学习曲线和易用性 Python vs. JavaScript:学习曲线和易用性 Apr 16, 2025 am 12:12 AM

Python更适合初学者,学习曲线平缓,语法简洁;JavaScript适合前端开发,学习曲线较陡,语法灵活。1.Python语法直观,适用于数据科学和后端开发。2.JavaScript灵活,广泛用于前端和服务器端编程。

如何使用Next.js(前端集成)构建多租户SaaS应用程序 如何使用Next.js(前端集成)构建多租户SaaS应用程序 Apr 11, 2025 am 08:22 AM

本文展示了与许可证确保的后端的前端集成,并使用Next.js构建功能性Edtech SaaS应用程序。 前端获取用户权限以控制UI的可见性并确保API要求遵守角色库

从C/C到JavaScript:所有工作方式 从C/C到JavaScript:所有工作方式 Apr 14, 2025 am 12:05 AM

从C/C 转向JavaScript需要适应动态类型、垃圾回收和异步编程等特点。1)C/C 是静态类型语言,需手动管理内存,而JavaScript是动态类型,垃圾回收自动处理。2)C/C 需编译成机器码,JavaScript则为解释型语言。3)JavaScript引入闭包、原型链和Promise等概念,增强了灵活性和异步编程能力。

如何安装JavaScript? 如何安装JavaScript? Apr 05, 2025 am 12:16 AM

JavaScript不需要安装,因为它已内置于现代浏览器中。你只需文本编辑器和浏览器即可开始使用。1)在浏览器环境中,通过标签嵌入HTML文件中运行。2)在Node.js环境中,下载并安装Node.js后,通过命令行运行JavaScript文件。

See all articles