【Vite】对 CSS 处理

Vite 会使用 esbuild 或 PostCSS 来转换 CSS 文件

Vite 解析 CSS 文件的过程:
① 使用 fs 模块读取 .css 文件的内容
② 创建一个 style 标签,将 .css 文件的内容 copy 到 style 标签内
③ 将 style 标签插入到 index.html 的 head 标签中
④ 将该 .css 文件的内容替换为 Js 脚本,以便于 CSS 模块化 & 热更新



CSS 模块化 (CSS Module)

在协同开发时,可能会出现相同的类名,该类名对应的样式就有可能被覆盖

import './componentA.css';

const div = document.createElement('div');
document.body.appendChild(div);
div.className = 'footer';
import './componentB.css';

const div = document.createElement('div');
document.body.appendChild(div);
div.className = 'footer';
.footer {
    width: 100px;
    height: 100px;
    background-color: aquamarine;
}
.footer {
    width: 100px;
    height: 100px;
    background-color: rgb(127, 197, 255);
}
import './componentA';
import './componentB';

yarn dev 启动服务器,可以看见两个 div 都是同一个颜色的,这就是因为相同类名之间发生样式覆盖了。


使用 CSS 模块化可以解决这个问题:

.footer {
    width: 100px;
    height: 100px;
    background-color: aquamarine;
}
.footer {
    width: 100px;
    height: 100px;
    background-color: rgb(127, 197, 255);
}
import componentACss from './componentA.module.css';

const div = document.createElement('div');
document.body.appendChild(div);
div.className = componentACss.footer;
import componentBCss from './componentB.module.css';

const div = document.createElement('div');
document.body.appendChild(div);
div.className = componentBCss.footer;

yarn dev 启动服务器,就可以看见两个 div 的颜色不一样啦


启动 CSS Module 需要将 .css 后缀改为 .module.css,这是一个约定


CSS Module 的作用步骤:

  1. 将 .css 文件中的类名按某种规则进行替换。eg: footer_footer_h08ai_1
  2. 创建映射对象,存储着类名被替换前后的映射 { footer: "_footer_h08ai_1" }
  3. 创建 style 标签,将替换类名后的 CSS 样式复制到里面
  4. 将 style 标签插入 index.html 的 head 标签中
  5. 将 XXX.module.css 的内容替换为 Js 脚本
  6. 将创建的映射对象在脚本中进行默认导出



构建 CSS 的配置项

import { defineConfig } from 'vite';

export default defineConfig({
    css: {}, // 配置 CSS 的构建方式
});

preprocessorOptions

配置 CSS 预处理器

import { defineConfig } from 'vite';

export default defineConfig({
    css: {
        // 配置 CSS 预处理器
        preprocessorOptions: {
            less: {},
            sass: {},
        },
    },
});

preprocessorOptions.less

less: {
    math: 'always', // 配置什么时候执行数学运算
    // 全局变量
    globalVars: {
        mainColor: 'blue',
    },
},

preprocessorOptions.sass

scss: {
    // 在每个 scss 文件的开头添加一些额外的数据, 通常用来导入一些全局的 scss 变量或样式文件
    additionalData: '@import "@/styles/variable.scss";',
},

devSourcemap

是否在开发模式下生成 CSS 的 sourcemap,这样可以在浏览器的开发者工具中查看你的原始的 CSS 代码

import { defineConfig } from 'vite';

export default defineConfig({
    css: {
        devSourcemap: true, // 默认为 false
    },
});

modules

配置 CSS 模块

import { defineConfig } from 'vite';

export default defineConfig({
    css: {
        // 配置 CSS 模块
        modules: {},
    },
});

modules.localsConvention:规范 CSS Module 中类名的书写格式

  • 'dashesOnly' 将映射对象中的类名都转换成中划线连接格式 (默认)
  • 'dashes' 将映射对象中的类名都转换成中划线连接格式,且保留其小驼峰格式
  • 'camelCaseOnly' 将映射对象中的类名都转换成小驼峰格式
  • 'camelCase' 将映射对象中的类名都转换成小驼峰格式,且保留其中划线连接格式
import { defineConfig } from 'vite';

export default defineConfig({
    css: {
        modules: {
            localsConvention: 'dashesOnly',
        },
    },
});

modules.generateScopedName:CSS Module 映射对象中 value 的命名方式

generateScopedName: '[name]-[contenthash:5]',

postcss

配置 PostCSS 的选项

import { defineConfig } from 'vite';
import postcssPresetEnv from 'postcss-preset-env';

export default defineConfig({
    css: {
        postcss: {
            plugins: [postcssPresetEnv()], // 使用预设
            // 需要先安装预设: `yarn add postcss-preset-env -D`
        },
    },
});

也可以使用 postcss.config.js 配置 postcss,postcss.config.js 的优先级会比 vite.config.js 的 css.postcss



PostCSS

PostCSS 是一种 CSS 处理工具,它可以让你使用一些高级的 CSS 特性,或者使用一些插件来扩展或优化你的 CSS 代码。

编译过程:
① 语法降级:用较低级的 CSS 语法替换高级 CSS 语法
② 前缀补全:部分浏览器能支持高级 CSS 语法,但需要添加指定前缀 (eg: --webkit)


使用 PostCSS:

  1. 安装依赖 yarn add postcss postcss-cli -D
    postcss-cli提供命令; postcss编译代码
  2. 安装预设 yarn add postcss-preset-env -D
    预设能帮你把编译所需的一些基本插件安装好,就不需要自己一个个安装啦
  3. 编写 PostCSS 配置文件
const postcssPresetEnv = require("postcss-preset-env");

module.exports = {
    plugins: [postcssPresetEnv()],
};
  1. 编写 example.css 文件
  2. 执行脚本 编译文件:npx postcss example.css -o result.css

处理 CSS 全局变量:

PostCSS 会一个个地对 .css 文件进行编译。假设有如下 .css 文件:

:root {
    --main-color: red;
}

div {
    background: var(--main-color);
}

会被编译成:

div {
    background: red;
    background: var(--main-color);
}

这会导致一个问题:在当前 .css 文件无法使用其他 .css 文件定义的 CSS 全局变量
为了解决这个问题,可以进行如下配置:

  1. 将所有的 CSS 全局变量都编写到一个 .css 文件中
  2. 配置 postcss.config.js 读取并存储全局变量
const postcssPresetEnv = require('postcss-preset-env');
const path = require('path');

module.exports = {
    plugins: [    
        postcssPresetEnv({
            // 读取并存储指定文件中配置的 CSS 全局变量
            importFrom: path.resolve(__dirname, './globalVariable.css'),
        }),
    ],
};

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: 要在 Vite 中使用 PostCSS Modules,你需要执行以下步骤: 1. 安装 `postcss-modules` 插件: ```bash npm install postcss-modules --save-dev ``` 2. 在 `vite.config.js` 中配置 PostCSS: ```javascript import vue from '@vitejs/plugin-vue' import postcssModules from 'postcss-modules' export default { plugins: [ vue(), ], css: { postcss: { plugins: [ postcssModules({ generateScopedName: '[name]__[local]___[hash:base64:5]', }), ], }, }, } ``` 在上面的配置中,我们使用 `postcss-modules` 插件并设置 `generateScopedName` 选项以生成唯一的 CSS 类名。 3. 在 Vue 组件中使用 CSS Modules: ```vue <template> <div :class="$style.title">Hello world!</div> </template> <style module> .title { font-size: 24px; color: red; } </style> ``` 在上面的示例中,我们使用 `module` 属性启用了 CSS Modules,并使用 `$style` 对象来引用生成的唯一类名。 注意,如果你使用的是 Vue 3,你需要使用 `@vue/compiler-sfc` 版本 `^3.0.0-0` 或更高版本,并在 `vue.config.js` 中设置 `compilerOptions` 选项: ```javascript module.exports = { ... compilerOptions: { moduleIds: 'module', ... }, } ``` ### 回答2: vite是一个快速的Web开发工具,它提供了许多配置选项来满足不同项目的需求。其中之一是配置postcss-modules。 PostCSS是一个用于对CSS进行处理的工具,它可以通过插件来实现不同的功能,例如自动添加浏览器前缀、转换CSS变量等。而postcss-modules则是其中的一个插件,它可以让我们在编写CSS时使用类似于JavaScript模块的方式来管理样式。 在vite项目中配置postcss-modules需要以下几个步骤: 1. 首先,安装postcss-modules和postcss插件。可以使用npm或者yarn来安装。 ```shell npm install postcss-modules postcss --save ``` 2. 在项目的根目录下创建一个postcss.config.js文件,在该文件中进行postcss-modules的配置。 ```javascript module.exports = { plugins: [ require('postcss-modules')({ // 配置postcss-modules的选项 // 这里可以配置一些自定义的CSS类名生成规则等 }), // 其他的postcss插件可以在这里添加 ], }; ``` 3. 在vite的配置文件vite.config.js中引入postcss插件,并将postcss-modules添加到它的插件数组中。 ```javascript import { defineConfig } from 'vite'; import postcss from 'rollup-plugin-postcss'; export default defineConfig({ plugins: [ postcss(), // 其他的插件可以在这里添加 ], }); ``` 这样就完成了vite项目中postcss-modules的配置。接下来,我们可以在编写CSS样式时使用类似于JavaScript模块的导入和导出语法来管理样式。 总结:通过在vite项目中进行postcss-modules的配置,我们可以使用类似于JavaScript模块的方式来管理样式。这样可以提高样式的可读性和维护性,并且可以避免全局命名空间的冲突问题。 ### 回答3: vite配置postcss-modules可以通过以下步骤实现: 1. 首先,确认你已经在项目中安装了vite。如果没有安装,可以在命令行中运行以下命令进行安装: ``` npm install -g create-vite ``` 2. 创建一个新的vite项目。在命令行中运行以下命令: ``` create-vite my-project ``` 这将创建一个名为`my-project`的新文件夹,并在其中初始化一个新的vite项目。 3. 进入新创建的项目文件夹。在命令行中运行以下命令: ``` cd my-project ``` 4. 安装postcss-modules。在命令行中运行以下命令: ``` npm install postcss-modules ``` 5. 打开vite配置文件`vite.config.js`,并添加postcss-modules的配置。可以使用ES模块的方式导入postcss-modules,并在`css`插件中进行配置。示例代码如下所示: ```js import { defineConfig } from 'vite'; import postcssModules from 'postcss-modules'; export default defineConfig({ plugins: [ // ... postcss({ plugins: [ postcssModules({ generateScopedName: '[name]__[local]--[hash:base64:5]' }) ] }) ] }); ``` 在上面的配置中,`generateScopedName`属性用于定义生成CSS作用域的名称。你可以根据自己的需求进行调整。 6. 保存并关闭`vite.config.js`文件。重新启动项目(如果已经启动的话),以使配置生效。 完成以上步骤后,你的vite项目就已经成功配置了postcss-modules。现在,你可以在项目中使用postcss-modules来管理CSS模块和样式作用域了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JS.Huang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值