个人写码感悟:TailwindCSS不要忽视子选择器

前段时间刷小红书看到这样一个贴子,其中作者配了这样一张图:

感觉很受启发,有时候自己嫌麻烦会在子组件上重复复制粘贴很多遍相同的样式代码,实际在其父组件中通过子选择器就可避免代码冗余的情况,刷过之后留了个印象。

今天在使用shadcn/ui的tabs组件时,我为了设置每个tab再悬浮时光标手势为pointer,未激活时字体为白色,背景为灰色,悬浮背景为浅灰色;激活时字体为黑色,背景为白色,悬浮背景不变色,我忽然想起了这个贴子,便想实际操作一下。

按照以往的写码习惯这些央视的编写会是下面这样:

js 复制代码
<TabsList className="flex-none w-full bg-gray-800 border-b border-gray-700 rounded-none h-auto">
    {CheckComponent && (
        <TabsTrigger
            value="check"
            className="flex-1 cursor-pointer text-white hover:bg-gray-700 data-[state=active]:text-black data-[state=active]:hover:bg-transparent"
        >
            Check
        </TabsTrigger>
    )}
    {CreateComponent && (
        <TabsTrigger
            value="create"
            className="flex-1 cursor-pointer text-white hover:bg-gray-700 data-[state=active]:text-black data-[state=active]:hover:bg-transparent"
        >
            Create
        </TabsTrigger>
    )}
    {EditComponent && (
        <TabsTrigger
            value="edit"
            className="flex-1 cursor-pointer text-white hover:bg-gray-700 data-[state=active]:text-black data-[state=active]:hover:bg-transparent"
        >
            Edit
        </TabsTrigger>
    )}
</TabsList>

而利用子选择器思路则是直接在每个TabsTrigger的父组件上用父级规则批量设置子组件样式:

js 复制代码
<TabsList className="flex-none w-full bg-gray-800 border-b border-gray-700 rounded-none h-auto 
    [&_button]:cursor-pointer 
    [&_button]:text-white 
    [&_button:not([data-state=active])]:hover:bg-gray-700 
    [&_button[data-state=active]]:text-black"
>
    {CheckComponent && (
        <TabsTrigger value="check" className="flex-1">
            Check
        </TabsTrigger>
    )}
    {CreateComponent && (
        <TabsTrigger value="create" className="flex-1">
            Create
        </TabsTrigger>
    )}
    {EditComponent && (
        <TabsTrigger value="edit" className="flex-1">
            Edit
        </TabsTrigger>
    )}
</TabsList>

这样做的优点在于方便后期做整体样式调整,而无需对每个TabsTrigger做一对一的修改,有些避免代码冗余,降低维护难度。

相关推荐
m0_6113493120 小时前
什么是副作用(Side Effects)
开发语言·前端·javascript
狗头大军之江苏分军20 小时前
她在结婚那天离开了:我们该重新谈谈“结婚这件事”
前端·后端
消失的旧时光-194320 小时前
从命令式跳转到声明式路由:前端、Android、Flutter 的一次统一演进
android·前端·flutter·状态模式
icestone_kai20 小时前
ngix开启跨域
前端
咸虾米_20 小时前
uniapp使用history路由模式打包上线到前端网页托管的注意事项
前端·uni-app·vue3·unicloud·前端网页托管
前端无涯20 小时前
React Router(web) 全解析:知识点、工作注意点及面试重点
前端·react.js·前端框架
EQ_雪梨蛋花汤20 小时前
【NDK / JNI】Sceneform-EQR 集成 Filament JNI 源码:关键点与逐步操作记录
前端
C_心欲无痕20 小时前
vue3 - shallowReactive浅层响应式对象(只对顶层属性)
前端·javascript·vue.js
AY呀20 小时前
新手必读:React组件从入门到精通,一篇文章搞定所有核心概念
前端·javascript·react.js
葛葵葵20 小时前
使用 AI Workflow 规范化团队 Commit 信息:从混乱到有序
前端