下一代 CSS 框架:Mojo CSS

news2024/9/24 1:24:35

前言

Tailwind CSS 推出即受到广大开发者的欢迎,当前 Github star 数已达 77.8k。它是一个功能类优先(utility-first)的 CSS 框架,它提供了一系列功能类,让开发者可以在 HTML 中通过组合这些功能类(原子类)的方式去快速构建用户界面。

本文将给大家分享下一代原子级 CSS 框架:Mojo CSS,并简要阐述其与 Tailwind CSS 的异同。

Mojo CSS 基本介绍

Mojo CSS 定位为下一代原子级 CSS 框架,是由 Mohammad Zamanian 和 Ali Mirabbasi 开发和维护的开源项目。

Mojo CSS 于 2023 年发布,该框架的工作原理是扫描你的代码并实时创建 CSS 视觉效果,而无需你编写新的 CSS 代码。它会根据 HTML 生成 CSS,可在不使用任何 CSS 的情况下制作华丽的用户界面。与 Tailwind 一样,Mojo CSS 也会移除未使用的 CSS,以提高页面性能并简化维护工作。

Mojo CSS 不仅仅是另一个 CSS 框架,它还是一种全新的样式设计方式,以易用性、定制化和速度优先。Mojo 的核心是一个超轻量级(约 15kb gzipped)的 JavaScript 引擎,它可以通过扫描页面上的实用工具动态生成 CSS。

快速安装:

npm install mojocss
# or

yarn add mojocss

为何 Mojo CSS 如此受欢迎?主要归因于一下方面:

1)自定义主题:

告别仅限于暗色模式的局限。Mojo 可让开发者定义无限的主题颜色,让您自由发挥创意,使您的项目真正独一无二。最棒的是什么?非常简单,只需选择三种主色调即可!

mojo({
  base: {
    themes: {
      default: {
        body: "#f2f7f9",
        invert: "#6b88a5",
        primary: "#ff6145",
      },
      // Try out different color themes,
      // make as many you want without worrying about overloading the project.
      dim: {
        body: "#1a2a39",
        invert: "#90a4b8",
      },
      blackout: {
        body: "#000",
        invert: "#999",
      },
    },
  }
});

2)CSS 选择器:

Mojo 打破常规,让您可以在 HTML 中使用真正的 CSS 选择器,并与框架的实用工具无缝集成。这对于那些渴望灵活性和可读性的用户来说,无疑是一场变革。

当 HTML 限制了复杂的 CSS 选择器时,Mojo 的任意选择器就会介入,使您能够在标记中利用原始 CSS 的强大功能,同时充分利用 Mojo 的实用工具。

只需使用 _="" 属性,并在括号中指定所需的选择器即可:

<ul _="(li.active) bg-c-red text-c-white" >
  <li>First Item</li>
  <li class="active">Second Item</li>
  <li>Third Item</li>
</ul>

3)内置色彩引擎:

Mojo 允许您使用无限的颜色以及无数的色调和色差,从而将颜色定制提升到一个新的水平。您的创造力无穷无尽。

<div>
  <div class="bg-c-primary:-10"></div>
  <div class="bg-c-primary:-5"></div>
  <div class="bg-c-primary"></div>
  <div class="bg-c-primary:+5"></div>
  <div class="bg-c-primary:+10"></div>
</div>

4)响应式设计:

Mojo 的响应式设计使用断点变量,告诉网站如何根据屏幕尺寸安排内容。将断点定义为变体,可以根据不同的屏幕尺寸轻松调整元素样式。每个实用工具类都有响应式变体。

5)模式进一步简化:

利用 CSS-IN-JS 语法和嵌套规则,Mojo 的模式简化了 CSS 的编写,使您能够应用全局样式或封装实用程序集,从而减少代码重复。

模式对象的结构如下:

mojo({
  patterns: {
      // Your Styles
  },
  // ... other configurations
});

6)尺寸至关重要:

作者深知轻量级框架的重要性。Mojo 简化后只有约 50kb 大小,压缩后只有约 15kb 大小,非常轻量。

缩小 Mojo 的大小并不意味着牺牲功能或灵活性。尽管体积小巧,但 Mojo CSS 提供了一套全面的实用工具,让您可以制作出美观、功能丰富的用户界面。它在效率和功能之间实现了完美平衡,让您的开发之旅更加顺畅愉快。

Mojo CSS vs Tailwind CSS

Mojo CSS 比 Tailwind 更好吗?下面将比较 Mojo CSS 和 Tailwind 的各种功能,看看哪一个更胜一筹。

1)浏览器兼容性:

首先需要提到的是浏览器兼容性,Tailwind 和 Mojo CSS 对现代浏览器支持很好,不会有太多的兼容性问题。

但 Mojo CSS 为了提供流畅的手机和电脑屏幕兼容性,使用了变体断点。开发者需要使用这些断点来应对网站如何调整大小和排列内容。

2)UI 主题和组件:

Tailwind 提供定制的用户界面组件,包括各种用户界面元素,如输入框、卡片和导航栏。这些组件是使用 Tailwind 的实用工具类构建的,可以实现彻底的定制和风格化。Tailwind 通过提供预定义的内置组件,简化了 CSS 设计过程。Tailwind 拥有 500 多个自定义组件和模板。

至于 Mojo CSS,文档网站上还没有提供模板,也没有发布 Mojo CSS 组件列表,但其自定义定制化主题可能会受到更多开发者的欢迎。

3)集成和扩展性:

Tailwind 拥有庞大的用户群,由此产生了许多插件和资源。你可以使用许多免费的 Tailwind 插件来改进 CSS,比如改进宽高比的插件。你可以在这里和 Tailwind 官方文档中找到更多 Tailwind CSS 插件。

因 Mojo CSS 还比较年轻,与 Tailwind CSS 相比,Mojo CSS 的扩展和插件很少。

但值得一提的是,Mojo CSS 拥有一个名为 Mojo CSS Intellisense 的 Visual Studio 扩展,只要在 Visual Studio 的 CSS 项目中添加 mojo.config.js 文件即可使用。该扩展将为您的 Mojo 实用程序提供自动完成功能,并支持 HTML、JavaScript 和 Vue.js 等语言和框架。

4)速度与性能:

Tailwind 以提供稳定可靠的版本而著称。它采用即时 CSS 编译器,只使用必要的 CSS,而不是预先编译所有内容。Tailwind 会向客户端发送 10kB 的 CSS,以改进 CSS。至于 Tailwind 的可靠性,它是有据可查的,也是公认的。

而 Mojo CSS 虽然没有遇到重大问题,但它是一款较新且测试较少的 CSS。尽管如此,Mojo CSS 的性能仍然令人印象深刻,这主要归功于其轻量级 CSS 样式组件,总大小仅为 50 kB,压缩后为 15 kB。

5)上手成本:

Tailwind 和 Mojo CSS 都有官网及完善的文档,上手成本不高。

使用 Tailwind 可以大大减少 CSS 的编写量,而使用 Mojo CSS 则无需编写任何 CSS。与 Mojo CSS 不同的是,Tailwind 需要对 HTML 和 CSS 有深入的了解。

总结

Tailwind 和 Mojo 这两个 CSS 框架都很优秀。但对于开发者的我们,能满足我们项目需求的才是最好的框架。Mojo CSS 是一款优秀的革命性 CSS 框架,相信它还有很长的路要走,未来可期!

—————————

推荐学习教程:阿里大牛600分钟精讲React全家桶让你从入门到精通(基础+进阶+实战+源码)

注:前端资料分享,(学习文档+面试八股文+场景题+简历模板+视频教程等)

仅供参考!!!

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

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

相关文章

阶段三:项目开发---大数据开发运行环境搭建:任务3:安装配置Hadoop集群

任务描述 知识点&#xff1a;安装配置Hadoop 重 点&#xff1a; 安装配置Hadoop 难 点&#xff1a;无 内 容&#xff1a; Hadoop是一个由Apache基金会所开发的分布式系统基础架构。用户可以在不了解分布式底层细节的情况下&#xff0c;开发分布式程序。充分利用集群的威…

Flink 提交作业的方式

参考&#xff1a; Flink运行方式及对比-腾讯云开发者社区-腾讯云

前端程序员如何转大模型?收藏这一篇就够了(非常详细)

最近各行各业都不容易啊&#xff0c;那个中金女员工跳楼事件频繁上热点&#xff0c;引起广泛的关注&#xff0c;本质上还是经济下行&#xff0c;我们互联网行业也是如此&#xff0c;特别是程序员&#xff0c;本来就有35岁危机&#xff0c;加上行业不景气&#xff0c;大厂都在裁…

C语言中的数组:掌握数据的有序集合【一维数组,二维数组,字符串数组,直方图打印,计算全排列,字符数组常用函数】

目录 C语言中的数组&#xff1a;掌握数据的有序集合【一维数组&#xff0c;二维数组&#xff0c;字符串数组】一维数组一维数组的创建数组的七种初始化完全初始化&#xff1a;部分初始化&#xff1a;字符数组的初始化&#xff1a;自动初始化为0&#xff1a;使用memset函数初始化…

C语言求10进制转2进制(除2取余法)

1.思路&#xff1a;除2取余法&#xff0c;也就是说用除以2取余来将10进制数转换为二进制 2.两种代码实现&#xff0c;这里用了两&#xff0c;一个递归一个非递归。 递归是一种编程技术&#xff0c;其中一个函数直接或间接地调用自己。递归通常用于解决那些可以被分解为更小的、…

QCC5181 歌词歌曲名多国语言显示替代QCC5125 CSR8675

QCC518X作为Qualcomm新一代蓝牙技术芯片&#xff0c;支持最新蓝牙协议V5.4&#xff0c;较QCC512X系列&#xff0c;它有更强大的DSP、CPU。除支持USB、I2S、SPDIF等接口外&#xff0c;还扩展了LE Audio功能&#xff0c;扩展支持AptX Lossless。以5181为例&#xff0c;我们还扩展…

Pandas 学习笔记(四)--CSV文件

CSV文件 CSV&#xff08;Comma-Separated Values&#xff0c;逗号分隔值&#xff0c;有时也称为字符分隔值&#xff0c;因为分隔字符也可以不是逗号&#xff09;&#xff0c;其文件以纯文本形式存储表格数据&#xff08;数字和文本&#xff09;。 读取与写入 读取csv文件 i…

智能充电(新能源电动车,电单车)云管理系统的定制解决方案

一 系统简介 智能充电&#xff08;新能源电动车&#xff0c;电单车&#xff09;云管理系统 是一套能够实现对充电站/桩的实时通讯、状态监控、故障检测、运营分析、数据统计、策略设置的智能化多任务管理系统。 二 平台概览 智能充电云管理系统 https://chongdianzhuang.itg…

C# CvDnn部署CoupledTPS实现旋转图像矫正

C# CvDnn部署CoupledTPS实现旋转图像矫正 目录 说明 效果 模型信息 项目 代码 下载 说明 TPAMI2024 - Semi-Supervised Coupled Thin-Plate Spline Model for Rotation Correction and Beyond github地址&#xff1a;https://github.com/nie-lang/CoupledTPS 代码实现…

【SpringCloud应用框架】Nacos命名空间、分组和DataID三者关系

第五章 Spring Cloud Alibaba Nacos之命名空间、分组和DataID三者关系 文章目录 一、名词解释三者关系 二、切换不同环境DataID方案Group方案Namespace空间方案 一、名词解释 命名空间&#xff08;Namespace&#xff09; ​用于进行租户粒度的配置隔离。不同的命名空间下&…

C++ 智能指针使用不当导致内存泄漏问题

shared_ptr相互嵌套导致循环引用 代码示例 #include <iostream> #include <memory> using namespace std;class B;class A { public:std::shared_ptr<B> b_ptr;~A() { std::cout << "A destroyed\n"; } };class B { public:std::shared_pt…

优选算法之技巧(一):双指针一:移位0与复写0

引用&#xff1a;我们之前学过快排&#xff0c;首先用三元取中&#xff0c;找(key)&#xff0c;然后就用到了双指针的方法来进行交换排序&#xff0c;那我们今天要讲的双指针其实大同小异&#xff0c;无非在数组中就变成了下标。 题一&#xff1a; 给定一个数组 nums&#xf…

云平台教程 | 手把手教你主成分分析PCA的可视化

爱基百客云平台小工具使用 1.1 爱基百客云平台之PCA分析 1.2 PCA分析原理 1.3 参数设置 1.4 任务查看 1.5 结果 1.5.1 PCA图 01 爱基百客云平台小工具使用 首先&#xff0c;打开爱基百客官网&#xff1a;http://www.igenebook.com&#xff1b;点击菜单栏最右侧“云平台”按钮…

藏汉翻译通工具推荐使用《藏文翻译词典》App:藏族文化的掌上宝典,帮助你了解学习藏语反义词近义词和藏文作文!

如果你正在学习藏语&#xff0c;遇到不同地区的发音不同时&#xff0c;卫藏语、安多语和康巴语&#xff0c;那么你需要一款好用的翻译和语音朗读工具&#xff0c;帮助你掌握藏语。 如果你正在用藏文写作文&#xff0c;发现一些词汇不会时&#xff0c;需要使用藏文词典&#xf…

盘点效率工具RunFlow那些容易被忽略的功能

本文我们将带您了解RunFlow有哪些容易被忽略、但是又非常实用的功能。 固定工作窗口 您还可以通过双击 Ctrl 键来切换窗口固定状态&#xff0c;您也可以在 热点事件 设置页面自定义该快捷键。 预览菜单内容 用浏览器打开剪贴板复制的URL 多行输入 按 CtrlEnter 或 ShiftEnter …

C语言 -- 深入理解指针(二)

C语言 -- 深入理解指针&#xff08;二&#xff09; 1. 数组名的理解2. 使用指针访问数组3. 一维数组传参的本质4. 冒泡排序5. 二级指针6. 指针数组7. 指针数组模拟二维数组8. 字符指针变量9. 数组指针变量2.1数组指针变量是什么&#xff1f;2.2 数组指针变量怎么初始化 10. 二维…

海外媒体发稿-全媒体百科

全球知名媒体机构 在全球范围内&#xff0c;有许多知名的新闻机构负责报道世界各地的新闻事件。以下是一些国外常见的媒体机构&#xff1a; AP&#xff08;美联社&#xff09;合众国际社&#xff08;UPI&#xff09;AFP(法新社)EFE&#xff08;埃菲通讯社&#xff09;Europa …

【vue】下载 打印 pdf (问题总结)- 持续更新ing

这里是目录标题 一、pdf1.查看 下载一、pdf 1.查看 下载 样式 Code<template><div><el-table :data="pdfList" style="width: 100%" border ><el-table-columnprop="index"label="序号"width="80"ali…

JVM:介绍

文章目录 一、什么是JVM二、JVM的功能1、解释和运行2、内存管理3、即时编译 三、常见的JVM四、Java虚拟机规范五、HotSpot发展历程 一、什么是JVM JVM的全称为Java Virtual Machine&#xff0c;Java虚拟机。本质上是一个运行在计算机上的程序&#xff0c;职责是运行Java字节码…

气膜体育馆作为临时赛场有哪些优势—轻空间

一、气膜体育馆简介 气膜体育馆是一种利用气膜技术建造的室内场馆&#xff0c;其结构主要由高强度膜材、充气系统和钢缆固定系统组成。通过向膜体内部充气&#xff0c;使其形成稳定的内部压力来支撑整个建筑结构。气膜体育馆因其快速建设、环保节能、灵活多样等优点&#xff0c…