[问题交流] 常见的 CSS 方案选择

2022-01-18 14:33:20 +08:00
 anc95

常见 CSS 方案简单总结

原生 CSS

优点:

  1. 简单

Less / Sass 等 CSS 预编语言

优点:

  1. CSS 基础上增强函数、theme 等特点(不过 css variable 也支持 theme )
  2. 编译可以做一些 treeshaking 的优化,体积相对 CSS 会更优一些

CSS/Less Module

这是一种 CSS In CSS 的方案

优点:

  1. 能解决样式冲突的问题

缺点:

  1. 相对应的缺点是样式不能自由覆写

CSS In JS

styld-componentsemotion css 为代表的一些方案

优点:

  1. 相比 CSS Module 而言,样式可在 JS 层灵活控制(如根据 JS 状态切换不同的样式,CSS Module 包括其它方案需要在 clssName 层控制)

缺点:

  1. 相对应的缺点是样式不能自由覆写
  2. 会写很多的冗余代码,样式不太好做复用?

Utility CSS

以 tailwind css 和 windcss 为代码的一些 CSS 方案。

问题

目前在考虑我的项目代码怎么写,感觉很难 all in 到其中一种方案里

咨询下贵站的大佬们平时都倾向于使用哪种或哪几种组合方案,及其原因

3998 次点击
所在节点    CSS
24 条回复
daysv
2022-01-18 14:38:25 +08:00
tailwind css 足矣
koor
2022-01-18 14:41:24 +08:00
rebass 搭配 styled-components
weixiangzhe
2022-01-18 14:41:31 +08:00
我还在用 CSS Module 配合 less, 主要是简单够用
zcf0508
2022-01-18 14:42:41 +08:00
在用 windicss ,主要是样式写起来很爽,不用跳去单独写 css
heyjei
2022-01-18 14:44:03 +08:00
现在流行 tailwind 了吗?看来要去学习了
ddiu8081
2022-01-18 14:47:16 +08:00
tailwind css ,能节省大量时间在起 class 名上
shyling
2022-01-18 15:13:28 +08:00
TomatoYuyuko
2022-01-18 15:16:56 +08:00
用过 tailwind css 但不太喜欢,个人比较沉迷手撸 sass 的快感
shyling
2022-01-18 15:17:46 +08:00
个人的感觉是 css module 不太喜欢,为了解决冲突带来的麻烦有点多,而且也解决不了命名难的问题。

css in js 就更麻烦了, 首先改 className 问题也不大,style={{ backgroundColor: a ? 'red': 'blue' }} 好像也没啥问题
newbieRenew
2022-01-18 15:19:56 +08:00
借助 Sass 纯手工打造。那个 tailwind 的用法简直是灾难,特别是官网的例子,完全弄成标记语言了,看似复用,其实完全背离了模块化的理念,耦合太多,一旦需要改变某个数值,改起来简直是灾难。
f056917
2022-01-18 15:32:44 +08:00
@TomatoYuyuko +1 ,我都是手撸的
f056917
2022-01-18 15:33:30 +08:00
主要是担心用别的会样式冲突
newbieRenew
2022-01-18 15:37:23 +08:00
tailwind 的糟点用一个例子来形容: 某个边栏,你命名为“nav-left”并置于左边。一天,需求变更为放在右边,为了让其他人看明白,你是可能会更改名字为“nav-right”并置于右边。当变更频繁、没有模块化时,你更改的地方可能会很多了。其实你可以更好的命名为“nav-side”,从样式表里来控制它的方位,无需更改页面布局。
XCFOX
2022-01-18 16:59:18 +08:00
小孩才做选择,大人 CSS In JS 、Utility CSS 全都要

https://fower.vercel.app/zh-cn/
https://xstyled.dev/
vanton
2022-01-18 17:20:40 +08:00
tailwind 使用起来就是灾难。

一旦有大量需要修改类似组件的需求,工作量远超过手写 css
yaphets666
2022-01-18 17:50:44 +08:00
专业的前端,做前端工程,只有一个选择,就是 scss
fortunezhang
2022-01-18 20:31:50 +08:00
个人现在只用 scss 。妥妥的生产力
Cbdy
2022-01-18 20:55:32 +08:00
分享一下我的实践的感想,你说的我基本都稍微用过,实际实践下来的话

CSS Modules ,公司项目,有一些用 CSS Modules 的,但个人项目已经不用了,以前用的也改造掉了

用 Emotion 写的石头剪刀布小游戏
https://github.com/alchemy-works/RPS

用 styled-components 写的五子棋小游戏
https://github.com/alchemy-works/gomoku

用 Tailwind CSS 写的 Todo List
https://github.com/alchemy-works/todo-list

实际是这么几种方案:

- CSS Modules (包括 Vue 的 SFC 中的 Scoped CSS ):依赖编译工具链,和原有写 CSS 体验最接近,单独的 CSS 文件
- CSS in JS ( styled-components 、Emotion 、styled-jsx 等):可以脱离编译工具链,更加灵活,和 JS 相性好
- CSS 原子类( Tailwind CSS 等):正经使用要编译工具链,使用成本有点大
- 行内 CSS:这个局限性太大了,在很少场景作为补充使用

我个人更倾向于 styled-components/emotion 这种 CSS in JS 的方案

快速写静态的小页面我可能会用 Tailwind CSS 一把梭
BealuoC
2022-01-18 20:56:59 +08:00
tailwind
doommm
2022-01-18 21:23:09 +08:00
推荐试试 tailwindcss 。我是用它结合传统的 scss ,配合 vue/react 的组件化使用

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/828993

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX