React【vite使用模块化css】

文章目录


前言

一般编写组件样式的时候我们都需要做对样式的模块化,以防止组件样式间的样式污染。

在vue中有hash限制选择器

c 复制代码
.vue[as12xs4] {}

在react中有样式模块化

c 复制代码
import style from "index.module.scss";

function com {
	return <div className={style.styleName}>txt</div>
}

一、使用步骤

1.vite初始化react项目

代码如下(示例):

c 复制代码
npm init vite@latest react-pro -- --template react-ts

2. 安装sass

c 复制代码
npm i sass -D

3. 增加声明文件

在src同级目录下增加typings.d.ts

c 复制代码
declare module "*.module.scss" {
	const classes:{[key:string]:string};
	export default classes;
}

4.配置ts.config.json

c 复制代码
include:['src','./typings.d.ts']

5.使用

定义index.module.scss文件

c 复制代码
//必须要有有效属性,空白类不抛出
.root {
	color:red;
}

组件使用

c 复制代码
import style from "./index.module.scss";
function com(){
	return <div className={style.root}>red color</div>
}

二、scss文件默认支持模块化,而无需加.module

scss模块化的操作是由post-css这个插件去做的,可以自定义一个vite插件去实现,自己想要的模块化逻辑。后续作者也会编写一个对应的插件放在GitHub上

相关推荐
一 乐2 小时前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
C_心欲无痕2 小时前
ts - tsconfig.json配置讲解
linux·前端·ubuntu·typescript·json
清沫2 小时前
Claude Skills:Agent 能力扩展的新范式
前端·ai编程
yinuo3 小时前
前端跨页面通信终极指南:方案拆解、对比分析
前端
yinuo4 小时前
前端跨页面通讯终极指南⑨:IndexedDB 用法全解析
前端
xkxnq4 小时前
第二阶段:Vue 组件化开发(第 16天)
前端·javascript·vue.js
烛阴4 小时前
拒绝配置地狱!5 分钟搭建 Three.js + Parcel 完美开发环境
前端·webgl·three.js
xkxnq4 小时前
第一阶段:Vue 基础入门(第 15天)
前端·javascript·vue.js
anyup6 小时前
2026第一站:分享我在高德大赛现场学到的技术、产品与心得
前端·架构·harmonyos
BBBBBAAAAAi6 小时前
Claude Code安装记录
开发语言·前端·javascript