本文介绍: Vite使用 esbuild 或 PostCSS 来转换 CSS 文件Vite 解析 CSS 文件过程:① 使用 fs 模块读取 .css 文件内容创建一个 style 标签,将 .css 文件内容 copystyle 标签内③ 将 style 标签插入index.htmlhead 标签中④ 将该 .css 文件的内容替换为 Js 脚本以便于 CSS 模块化 & 热更新# CSS 模块化 (CSS Module)在协同开发时,可能出现

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

Vite 解析 CSS 文件的过程
使用 fs 模块读取 .css 文件的内容
创建一个 style 标签,将 .css 文件的内容 copystyle 标签
③ 将 style 标签插入index.htmlhead 标签
④ 将该 .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.htmlhead 标签中
  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 中类名的书写格式

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 配置 postcsspostcss.config.js优先级会比 vite.config.jscss.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'),
        }),
    ],
};

原文地址:https://blog.csdn.net/Superman_H/article/details/130174266

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_41762.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注