npm 包:ember-cli-atomizer 使用教程

简介

ember-cli-atomizer 是一个非常实用的 ember-cli add-on,它可以将模板中的样式和 HTML 元素进行分类,并且生成一个 Atomizer 配置文件,用于将这些分类的样式转换为一个 CSS 文件。这个过程通过 PostCSS 进行,因此也允许使用您最喜欢的 CSS 预处理程序。

安装

使用 npm 来进行安装:

--- ------- ---------- ------------------

使用

ember-cli 项目的根目录下,运行以下命令来创建一个 Atomizer 配置文件:

----- - ------------------

在成功创建配置文件之后,您将可以发现在项目根目录下多出了一个名为 atomizer-config.js 的文件。

在此之后,您可以使用以下命令来将您的模板转换为一个 CSS 文件:

----- --------

配置文件

Atomizer 配置文件是一个用于 Atomizer 的 JSON 配置文件。您可以自己编写配置文件,但是比较推荐的方式是使用 ember-cli-atomizer 来自动生成一个基本配置文件。

您可以通过以下命令来自动生成一个基本的 Atomizer 配置文件:

----- - ---------------

此命令将在您的源代码目录下创建一个名为 build-config/atomizer.json 的文件。

配置说明

以下是 Atomizer 配置文件的一些重要说明:

  • classNames: 这是一个对象,用于指定您项目中的所有类名。这些类名将在 Atomizer 中被分类,并且用于后续生成 CSS。
  • breakPoints: 这是一个对象,指定您项目中的所有断点。这些断点将用于 Atomic 类名之间的惰性和默认样式。
  • classNamesBlacklist: 一个对象或一个数组。将这些类名从生成的 CSS 文件中排除。这在您需要使用外部样式(例如,引入第三方库)时是非常有用的。
  • combinators: 这是一个对象,用于指定 Atomizer 在转换期间使用的组合器。默认的组合器包括 ~+> (空格)等。
  • custom": {}: 这是一个对象,用于添加您自己的 Atomizer 原子规则或者修改默认规则。

示例

以下是一个基本应用的示例:

安装

--- ------- ---------- ------------------
----- - ------------------
----- - ---------------

基本配置

以下是一个简单的配置文件,用于将 bg-red 类名编译为一个具有 background: red 样式的 css 规则:

-- --------------------------
-
  ------------- -
    --------- ------------ ----
  -
-

这个配置文件将会被用来生成一个 CSS 文件:

------- ------------ ----

使用组合器

如果您的选择器需要使用组合器,您需要在 combinators 对象中指定:

-- --------------------------
-
  ------------- -
    ------ ------- -----
    ------ ------------ ------
    ---- - ----- -
      -------- --------
      ------------- ------
    --
    ---- - ----- -
      -------- ----------
      ------------- ------
    -
  --
  -------------- -
    ---- - - --
    ---- - - -
  --
-

这个配置文件将编译为以下 CSS:

---- ------- ----
---- ------------ -----
---- - ---- ------- ----------------- -----
---- - ---- ------- ------------------- -----

结论

ember-cli-atomizer 为我们提供了一种便捷和高效的方式来分类和组织样式类名。无论是大型的还是小型的 Web 项目,都能够轻松地使用它。传统的 CSS 架构面临混乱和难与维护的问题,而 Atomizer 能够解决这些问题,并能够让我们的 CSS 代码更具有可读性和可维护性。

参考

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/60065f77238a385564ab6911


猜你喜欢

  • npm 包 react-reality-cli 使用教程

    在前端开发中,虚拟现实技术可以为用户带来更加真实的交互体验。而使用 React 库进行虚拟现实开发,则需要使用 npm 包 react-reality-cli。 本篇文章将详细介绍 react-rea...

    3 年前
  • npm 包 rollup-plugin-i18n 使用教程

    随着全球化的趋势,多语言的应用越来越普遍,前端也不例外。本文将介绍一款 npm 包——“rollup-plugin-i18n”,它是一款用于处理多语言的 rollup 插件。

    3 年前
  • npm 包 @coracain/tab-table-block 使用教程

    简介 在前端开发中,表格是一种常见的数据展示方式,但是单纯的表格可能显示效果并不好,且交互体验不佳。要解决这个问题,我们可以通过引入一些表格增强库来优化表格的展示效果与交互体验。

    3 年前
  • npm 包 @eim-materials/basic-fail-dialog-block 使用教程

    在前端开发中,我们经常需要使用对话框组件,而 @eim-materials/basic-fail-dialog-block 就是一个优秀的基础对话框组件,可以帮助我们快速构建一个弹出框来显示错误信息或...

    3 年前
  • npm 包 @eim-materials/basic-success-dialog-block 使用教程

    前言 在前端开发中,弹窗对于用户体验和交互效果是非常重要的。而现在很多弹窗的样式和功能都相似,在每次开发过程中都需要重新写代码,这会浪费大量的时间和精力。因此,有一个好的弹窗组件能够减少重复的工作量,...

    3 年前
  • npm 包 eim-pc-admin-lite 使用教程

    前言 随着互联网的发展,前端开发也越来越受到重视。前端工程师的技术栈也在不断扩大,其中使用 npm 包管理工具来加速开发是一个非常重要的技能。本文将介绍 npm 包 eim-pc-admin-lite...

    3 年前
  • npm 包 ngx.superlayer 使用教程

    在前端开发过程中,我们经常需要使用弹出层组件来实现一些交互操作,比如提示信息、确认框、登录框等等。在 Angular 中,ngx.superlayer 就是一个非常方便的弹出层组件,它支持多种样式、动...

    3 年前
  • npm 包 sxpay-cli 使用教程

    前言 在开发前端项目时,我们经常需要进行页面的样式设计,而样式设计中又有许多复杂繁琐的工作,比如各种浏览器兼容性,css 预处理器,样式表压缩等等。相信很多前端开发者都遇到过这些问题,并且会觉得这些问...

    3 年前
  • npm 包 react-inverted-scrollview 使用教程

    在前端项目开发过程中,常常需要使用滚动视图来展示大量的数据,然而大多数情况下,我们展示的数据都是从最新的开始展示。如何在 React 中实现一个反向滚动视图呢?今天我们要介绍的是一个非常实用的 npm...

    3 年前
  • npm包 @coracain/basic-fail-dialog-block 使用教程

    介绍 @coracain/basic-fail-dialog-block 是一个在前端开发中非常实用的npm包,它可以让开发者快速搭建一个基础的失败弹框和提示块,让用户在使用过程中更好的感知失败信息。

    3 年前
  • npm 包 @esentri/true-object-store 使用教程

    简介 @esentri/true-object-store 是一个用于构建 JavaScript 应用程序的 NPM 包,它提供了一种结构化的方式来存储和管理对象数据。

    3 年前
  • npm 包 @sigodenh/dee-utils 使用教程

    简介 @sigodenh/dee-utils 是一个实用的 JavaScript 工具库,提供了一系列常见、常用且易于使用的工具函数,帮助前端开发者快速提升开发效率,减少代码量。

    3 年前
  • npm包example-files的使用教程

    简介 example-files是一个用于发布npm包时,将例子文件一并打包发布的小工具。它可以帮助开发者更方便地使用、展示和测试他们的代码库,同时也为使用库的人提供更加清晰的上下文和更好的学习体验。

    3 年前
  • npm 包 rpscript-api-mathjs 使用教程

    介绍 rpscript-api-mathjs 是一个基于 math.js 的 npm 包,适用于前端开发人员。它可以帮助您快速处理数学运算,从而提高开发效率。 安装 首先需要在你的项目中安装 math...

    3 年前
  • npm 包 @eim-materials/crop-block 使用教程

    前言 在前端开发中,图片裁切是常见的需求。而 @eim-materials/crop-block 包就提供了一种简单的解决方案。 本文将详细介绍该 npm 包的使用方法,包括安装、API、示例代码及注...

    3 年前
  • npm 包 opentrack 使用教程

    前言 在进行前端开发时,我们经常会遇到需要追踪用户行为的情况。而 opentrack 就是一个非常优秀的 npm 包,它可以帮助我们完成这个任务,记录用户在页面上的行为,并将这些数据发送到服务器上,以...

    3 年前
  • npm 包 styled-console-log 使用教程

    在前端开发中,console.log 已经成了日常必备的调试工具。然而,原生的 console.log 很难区分不同信息级别的输出,而且输出样式单一,不容易吸引开发者的注意力。

    3 年前
  • npm 包 @use-angular/markdown 使用教程

    简介 在前端开发过程中,我们经常需要标记和渲染文本。而 Markdown 作为一种轻量级的标记语言,已经被广泛地应用在各个领域中。 @use-angular/markdown 是一个 Angular ...

    3 年前
  • npm 包 fablabsjs 使用教程

    介绍 fablabsjs 是一个基于 Three.js 库的 JavaScript 库,专门用于创建交互式的 3D 模型和场景。它提供了各种实用、易于使用的函数和对象,可简化开发者创建 3D 场景的过...

    3 年前
  • npm 包 fs-watch-exec 使用教程

    在日常前端开发中,经常需要监听文件的变化,例如自动编译 Less 或者打包,自动刷新浏览器等。Node.js 中的 fs 模块提供了读写文件的操作,但并不能实现文件变化的监听。

    3 年前

相关推荐

    暂无文章