个人写码感悟: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做一对一的修改,有些避免代码冗余,降低维护难度。

相关推荐
一叶茶12 分钟前
移动端平板打开的三种模式。
前端·javascript
前端大卫14 分钟前
一文搞懂 Webpack 分包:async、initial 与 all 的区别【附源码】
前端
Want59535 分钟前
HTML音乐圣诞树
前端·html
老前端的功夫1 小时前
前端浏览器缓存深度解析:从网络请求到极致性能优化
前端·javascript·网络·缓存·性能优化
Running_slave2 小时前
你应该了解的TCP滑窗
前端·网络协议·tcp/ip
程序员小寒2 小时前
前端高频面试题之CSS篇(一)
前端·css·面试·css3
颜酱2 小时前
Monorepo 架构以及工具选型、搭建
前端·javascript·node.js
oden2 小时前
ChatGPT不推荐你?7个GEO技巧让AI主动引用你的内容
前端
李游Leo3 小时前
前端安全攻防指南:XSS / CSRF / 点击劫持与常见防护实践(含真实案例拆解)
前端·安全·xss
我命由我123454 小时前
微信开发者工具 - 模拟器分离窗口与关闭分离窗口
前端·javascript·学习·微信小程序·前端框架·html·js