Tailwindcss尤大神都fork了,是未来的趋势?

最近Tailwindcss频繁出现在我的视野里,从单词拼写中看,多多少少与css有点关系。近几年是JS框架大行其道,CSS方面少有新的框架出现。

昨天突然看到尤大神在Github上的动态,fork了该项目,看来马上要火的节奏啊!

我们来看下这个tailwindcss究竟是个什么东西,有什么独特的功能和优势,最重要的是能否给我们开发者带来显而易见的效率的提升。

首先看官网对它的定义

Rapidly build modern websites without ever leaving your HTML.

tailwindcss 基于比组件更小、更灵活的工具类思想的 CSS 框架。这个思想简单来说就是用 class 保证灵活、便于自定义组件,而不是在组件基础上实现个性化。

可以看到代码的特点是一个Html标签伴随着一堆的CSS类,这种写法好像也不陌生。就是将样式封装的粒度更细。所以很多人看到就说“这不就是原子类吗?”。

我们先来看看Tailwindcss作者所谈到的开发初衷,将CSS开发经历分为几个不同的阶段来讲:

第一阶段语义化CSS

以 CSS 在 HTML 中的语义来命名 CSS 类名

缺点:HTML 达到了「分离关注」的目的,无需关心 CSS 了,但是 CSS 的结构与 HTML 的结构强耦合,几乎就是 HTML 结构的复刻。

第二阶段:将「样式(CSS)」与「结构(HTML)」解耦

典型代表:BEM 方法论

实际工作中,面临的两难境地:语义化 CSS,

在内容中立(content-agnostic)组件中,HTML 是独立的,CSS 依赖 HTML,导致的结果:HTML 可以方便地调整样式,CSS 不能方便地重用。

每个项目负责人都要意识到,「分离关注」并非是一个非黑即白的选择,而是一个权衡(tradeoff),一边是方便地调整样式,一边是方便地复用样式。

考虑到:

  1. HTML 是结构化的信息,具有明显的约束(如:标签种类等)

  2. CSS 是创造性灵感类信息,有极大的发散空间,达成相同效果有多种方式,无约束且易被滥用,被滥用后容易导致 UI 的不一致性

作者坚定的选择

「方便地复用 CSS」,为 CSS 增加约束,提升 UI 一致性。

第三阶段:内容中立组件

一个组件做得越多,或者一个组件越具体,越难以复用

第四阶段:内容中立组件 + 功能类(utility classes)

通过细粒度的功能类的组合,可以有效去除 CSS 中的重复

第五阶段:功能类优先(Utility-first)CSS

将所有的 CSS 均由功能类组合而成,这样做的好处是:对 CSS 的使用施加约束,有利于产生更一致的 UI,但是如果一个组件被多次使用,却每次都要用功能类组合而成么?

原则是:

  • 以功能类组合成组件

  • 避免过早抽象
    注:这里有个很好用的规则:直到一个模式出现 3 次的时候,再考虑抽象成组件,而非像 BEM 等方法论所做的那样,一开始就提供组件。


其实从我自己的开发经历来讲,主要分为两个时代,在这之前,编写 CSS 被认为是在为 HTML 文档进行排版。因此,“内容(HTML)、样式(CSS)、行为(JS)需要分离”这句话,连同着“CSS 代码应当体现 HTML 文档结构/语义”的观念深入人心。因此大家一直习惯于:

  • 为 HTML 文档里的一些元素起一些所谓“能反映它在文档里的角色/语义”的类名 / ID(例如 header、sidebar、menu、navbar 等等,甚至发明出 BEM 之类的“命名规范”),然后用类选择器或 ID 选择器来选中它们

  • 偶尔搭配使用那些依赖于文档结构的 CSS 选择器(后代选择器、子选择器、兄弟选择器等等)

但是,在 近几 年,没有人还会认为自己在编写 HTML 文档,或者说,认为自己的 HTML 是所谓的“内容”。HTML 实际上是类似于 GUI 像素 / 控件一类的东西,是组件的渲染产物。对于这种“渲染产物”,大家需要的是能够方便地指定其外观的方案,而不愿意再走“ 纵览文档结构 -> 为元素起名字 -> 用选择器选中 -> 写 CSS 语句”这套传统流程:

  • 由于组件化开发模式的推行,已经不存在一个所谓的“文档结构”了(现在只有组件树结构,而且你通常不会在乎它),也就是传统流程的第一步早已不复存在

  • 为了消灭第二、三步, CSS-in-JS 开始流行起来

  • 而 tailwind 这种原子类方案就更激进了,它不但跳过了传统流程的前三步,连第四步都帮你简化了(用一个简短的单词,也就是一个原子类,来代替一个 CSS 语句)

看了网上的开发者的评论,有人唱衰有人叫好,本人看来,一个东西的流行短时间可能是玄学,但是长时间流行的东西肯定是真的具有不可替代的优势。Tailwindcss也是如此,不要过早的判定一个东西的好坏吧,要结合时代趋势来看。既然大神都fork了,还是先用用看吧。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/354643.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JUnit 5 –架构

现在我们知道如何设置JUnit 5并使用它编写一些测试 ,下面让我们看一下。 在本文中,我们将讨论JUnit 5架构以及采用这种方式的原因。 总览 这篇文章是有关JUnit 5的系列文章的一部分: 设定 基本 建筑 条件 注射 … JUnit 4 忽略Hamcre…

前端程序员书桌上不可缺少的CSS书籍

作为前端,CSS不仅要会,而且要精通,随着各种浏览器规范参差不齐和网页交互多元化的趋势越来越复杂,前端程序员必须要将CSS基础知识打牢。由于现在的框架越来越多,导致很大一部分程序员的工作只是拿着现成的组件布局&…

nodejs 进阶:图片缩小

demo 效果: 代码: /*** Created by ZXW on 2017/10/30.*/ var fs require(fs); var gm require(gm);gm(./不饿.jpg).resize(50, 50,"!").write(./不饿1.jpg, function (err) {if (!err) console.log(done);});2017-10-30 22:10:46转载于:ht…

可能是最先出来的关于介绍使用Vue3的一本书

Vue3 release版本已发布有几个月了,不少公司都已经开始使用vue3开发项目了,市场上的主流的框架如:Vant,Element UI,Taro也都发布了支持Vue3的版本。Vue3很多的开发优势自不必再说,学习上手vue3已经成为每个…

CSGL

glShadeModel void glShadeModel(GLenum mode) GL_FLAT/【GL_SMOOTH】 着色技术选择 glClearDepth GL.glClearDepth(depth); glClearDepth:设置深度缓存的清除值 参数 depth 指定清除深度缓存时使用的深度值。 说明 本函数指定用glClear清除深度缓存时所使用的深度值…

强大的Canvas开源库Fabric.js简介与开发指南

什么是Fabric.js?Fabric.js 是一个强大且简单的Javascript HTML5 Canvas库。官网地址:http://fabricjs.com/为什么要使用Fabric.js?Canvas提供一个好的画布能力, 但是Api不够友好。绘制简单图形其实还可以, 不过做一些复杂的图形绘制, 编写一…

模拟qq斗地主-准备发牌抢地主都是农民下一轮准备

为什么要搞这样一个项目?? 1,满足自己的java网络多线程编程的欲望!因为之前一直都是搞web开发,服务器和客户端数据交流人家web服务器早就给你搞好了,比如tomcat,jetty...等等,其实之前脑子里就有…

rube3xxx_Rube GoldbergSpring整合

rube3xxxSpring Integration为集成系统所涉及的一些复杂性提供了非常好的抽象-Spring Integration从Integration的角度完美地满足了Facade的定义-简化了对复杂基础系统的访问。 为了说明这一点,请考虑一个简单的系统,该系统仅接收一条消息,然…

纯CSS实现React Logo图形,内含详细解析

以上是将要实现的效果&#xff0c;Javascript框架React的Logo图形&#xff0c;首先我们来拆解下&#xff0c;它包括三个交叉的椭圆和中间一个圆点&#xff0c;所以我们Html元素可以用以下代码实现&#xff1a;<div class"main"><div class"ellipse ell…

二次优化大招(由泰勒公式推出最值条件)

经过前两篇的铺垫&#xff0c;这一篇迎来了高潮。先说一句&#xff1a;特征值大法好&#xff01; 在开始正文之前&#xff0c;先看以下简单的推导 有了这些&#xff0c;理解下面的泰勒公式推出最值条件就容易了 转载于:https://www.cnblogs.com/Mr-ZeroW/p/7764916.html

前端自动化测试浅析

前言&#xff1a;测试简介前端常见的问题&#xff1a;修改某个模块功能时&#xff0c;其它模块也受影响&#xff0c;很难快速定位bug多人开发代码越来越难以维护不方便迭代&#xff0c;代码无法重构代码质量差增加自动化测试后&#xff1a;我们为核心功能编写测试后可以保障项目…

使用SpringData出现java.lang.AbstractMethodError

最近学习一下SpringData&#xff0c;在添加SpringData支持的时候&#xff0c;出现了这样的问题&#xff1a; SpringData需要的jar有:spring-data-jpa.jar spring-data-commons.jar slf4j-api.jar 没有添加slf4j也会出现一个异常&#xff0c;不过那个异常说的非常明确&#xf…

2021这份电子书单请收好(品类齐全)!

2021年已经快过去一个月了&#xff0c;今年的读书计划有没有安排上&#xff0c;这里有份长长的书单&#xff0c;多年的积累&#xff0c;品类齐全&#xff0c;赶快从中挑几本加入今年的读书计划里。•《货币战争2&#xff1a;金权天下》 - 宋鸿兵.mobi•《圣经》中英对照豪华版 …

在Kotlin中使用libGDX

最近&#xff0c;我一直在阅读有关不同语言的信息&#xff0c;以及它们可以为已经拥挤的软件开发人员带来什么&#xff0c;而一种语言对我来说很突出&#xff1a;Kotlin。 &#xff08; https://kotlinlang.org/ &#xff09; 这是一种相对较新的语言&#xff08;成立于2011年…

【重学JS系列】slice用法大合集

让我们回顾下slice的日常用法slice 工作原理在深入研究一些更高级的用法之前&#xff0c;让我们看一下slice方法的基础知识。如MDN文档&#xff0c;slice 是数组上的一个方法&#xff0c;它最多有两个参数:arr.slice([begin[, end]])begin从该索引处开始提取原数组中的元素,如果…

【Github开源】一站搞定各种开发文档

开发者的苦恼&#xff1a;经常要在多个API文档中切换&#xff0c;浏览器书签栏收藏各种语言相关的接口说明文档。无意中在Github上发现DevDocs[1]这个开源项目&#xff0c;它是一个把所有开发相关的文档以web的形式做了一个综合的网站&#xff0c;并提供搜索&#xff0c;离线访…

javafx 表单_JavaFX 2:创建登录表单

javafx 表单在本教程中&#xff0c;我将使用JavaFX 2和CSS设计一个外观漂亮的Login Form 。 它是经典的登录表单&#xff0c;带有用户名和密码以及登录按钮。 为了遵循本教程&#xff0c;我强烈建议您查看以下这些教程&#xff1a; Eclipse IDE中的JavaFX 2入门 JavaFX 2&…

【详细教程】教你如何使用Node + Express + Typescript开发一个应用

Express是nodejs开发中普遍使用的一个框架&#xff0c;下面要谈的是如何结合Typescript去使用。 目标 我们的目标是能够使用Typescript快速开发我们的应用程序&#xff0c;而最终我们的应用程序却是编译为原始的JavaScript代码&#xff0c;以由nodejs运行时来执行。 初始化设置…

结构型模式 适配器模式

结构型模式 适配器模式 适用于&#xff1a; 是将一个类的接口转换成客户希望的另外一个接口。使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。 /*** 结构型模式 适配器模式* Adapter模式也叫适配器模式&#xff0c;是构造型模式之一&#xff0c;通过Adapter模式可…

乐哥学AI_Python(二):Numpy索引,切片,常用函数

Numpy的索引和切片 ndarray对象的内容可以通过索引和切片查看和修改。 索引&#xff1a;ndarray对象中的元素索引基于0开始 切片&#xff1a;对数组里某个片段区域的描述 数组的切片也可以理解为原始数组的局部视图&#xff0c;都是指向内存中的原始数组&#xff0c;所以不同于…