在Create React App中使用CSS Modules的方法示例


Posted in Javascript onJanuary 15, 2019

前提条件

请先进行全局安装 create-react-app 插件哈,安装命令:npm install create-react-app -g

先使用 create-react-app 命令下载一个脚手架工程,安装命令:

# 使用 npx
$ npx create-react-app my-app

# 使用 npm 
$ npm init npx create-react-app my-app

# 使用 yarn
$ yarn create react-app my-app

运行项目

$ cd my-app

# 使用 npm
$ npm start

# 或者使用yarn
# yarn start

在浏览器中输入 http://localhost:3000 查看项目效果

使用 CSS Module 的第一种方式

create-react-app 中内置了使用 CSS Modules 的配置,当前方式就是使用 create-react-app 内置的用法

方式

将所有的 .css/.lee/.scss 等样式文件都修改成 .module.css/.module.less/.module.scss 等。即可使用 CSS Modules 的方式进行引入使用了。

用法

编写一个 css 文件:Button.module.css

.error {
  background-color: red;
}

在编写一个普通的 css 文件:another-stylesheet.css

.error {
  color: red;
}

在 js 文件中使用 CSS Modules 的方式进行引用:Button.js

import React, { Component } from 'react';
import styles from './Button.module.css'; // 使用 CSS Modules 的方式引入
import './another-stylesheet.css'; // 普通引入

class Button extends Component {
 render() {
  // reference as a js object
  return <button className={styles.error}>Error Button</button>;
 }
}

在浏览器中查看效果

此时 Button 组件的背景颜色是红色,但是字体颜色却不是红色,因为使用了 Css Modules 之后,普通的 css 样式就不起效果了,需要用全局的方式编写才可以(:global)。 最后添加到元素上的样式结果为: <button class="Button_error_ax7yz">Error Button</button>

使用 CSS Module 的第二种方式

方式

在命令行运行 npm run eject 命令

此命令会将脚手架中隐藏的配置都展示出来,此过程不可逆

运行完成之后,打开 config 目录下的 webpack.config.js 文件,找到 test: cssRegex 这一行

在 use 属性执行的方法中添加 modules: true ,如下图:

在Create React App中使用CSS Modules的方法示例 

用法

和第一种方式的用法一致,只是不需要在 css 文件后面加 .module 后缀了

编写一个 css 文件:Button.css

.error {
  background-color: red;
}

再编写一个普通的 css 文件:another-stylesheet.css

.error {
  color: red;
}

在 js 文件中使用 CSS Modules 的方式进行引用:Button.js

import React, { Component } from 'react';
import styles from './Button.css'; // 可以直接使用 CSS Modules 的方式引入了
import './another-stylesheet.css'; // 普通引入

class Button extends Component {
 render() {
  // reference as a js object
  return <button className={styles.error}>Error Button</button>;
 }
}

在浏览器中查看效果

此时 Button 组件的背景颜色是红色,但是字体颜色却不是红色,因为使用了 Css Modules 之后,普通的 css 样式就不起效果了,需要用全局的方式编写才可以(:global)。 最后添加到元素上的样式结果为: <button class="Button_error_ax7yz">Error Button</button>

如想使用第二种方式对 sass 和 less 也使用 CSS Modules 的方式进行引用,则类似的在 sass 和 less 解析配置上也添加modules: true 即可。

注意

默认 create-react-app 脚手架不能直接使用 sass 和 less 直接编写 css,需要先进行相应配置。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js截取中英文字符串、标点符号无乱码示例解读
Apr 17 Javascript
js Object2String方便查看js对象内容
Nov 24 Javascript
JavaScript面向对象程序设计教程
Mar 29 Javascript
js 获取经纬度的实现方法
Jun 20 Javascript
JavaScript基本类型值-Undefined、Null、Boolean
Feb 23 Javascript
JavaScript限制在客户区可见范围的拖拽(解决scrollLeft和scrollTop的问题)(2)
May 17 Javascript
Vue实现virtual-dom的原理简析
Jul 10 Javascript
Vue组件中slot的用法
Jan 30 Javascript
vue插件mescroll.js实现移动端上拉加载和下拉刷新
Mar 07 Javascript
利用angular自动编译andriod APK的绕坑经历分享
Mar 08 Javascript
浅谈KOA2 Restful方式路由初探
Mar 14 Javascript
微信小程序wx.request拦截器使用详解
Jul 09 Javascript
Vue 样式绑定的实现方法
Jan 15 #Javascript
在vue使用clipboard.js进行一键复制文本的实现示例
Jan 15 #Javascript
2019 年编写现代 JavaScript 代码的5个小技巧(小结)
Jan 15 #Javascript
mock.js实现模拟生成假数据功能示例
Jan 15 #Javascript
详解webpack引入第三方库的方式以及注意事项
Jan 15 #Javascript
JS高阶函数原理与用法实例分析
Jan 15 #Javascript
JS立即执行函数功能与用法分析
Jan 15 #Javascript
You might like
提问的智慧(2)
2006/10/09 PHP
php中in_array函数用法分析
2014/11/15 PHP
在WordPress的后台中添加顶级菜单和子菜单的函数详解
2016/01/11 PHP
PHP实现的多维数组去重操作示例
2018/07/21 PHP
PHP PDOStatement::fetch讲解
2019/01/31 PHP
Dojo 学习笔记入门篇 First Dojo Example
2009/11/15 Javascript
Javascript中对象继承的实现小例
2014/05/12 Javascript
jquery制作select列表双向选择示例代码
2014/09/02 Javascript
jquery 标签 隔若干行加空白或者加虚线的方法
2016/12/07 Javascript
bootstrap select插件封装成Vue2.0组件
2017/04/17 Javascript
extjs简介_动力节点Java学院整理
2017/07/17 Javascript
Vue单文件组件基础模板小结
2017/08/10 Javascript
利用vue + element实现表格分页和前端搜索的方法
2017/12/25 Javascript
jsonp跨域获取数据的基础教程
2018/07/01 Javascript
Vue.js实现数据响应的方法
2018/08/13 Javascript
Vue.js获取被选择的option的value和text值方法
2018/08/24 Javascript
解决Vue.js由于延时显示了{{message}}引用界面的问题
2018/08/25 Javascript
Vue 配合eiement动态路由,权限验证的方法
2018/09/26 Javascript
详解从0开始搭建微信小程序(前后端)的全过程
2019/04/15 Javascript
Vue Router history模式的配置方法及其原理
2019/05/30 Javascript
React中使用Vditor自定义图片详解
2020/12/25 Javascript
python实现各进制转换的总结大全
2017/06/18 Python
利用Opencv中Houghline方法实现直线检测
2018/02/11 Python
Python3.4实现远程控制电脑开关机
2018/02/22 Python
Python装饰器知识点补充
2018/05/28 Python
Django ORM 查询管理器源码解析
2019/08/05 Python
python3 requests库文件上传与下载实现详解
2019/08/22 Python
pandas条件组合筛选和按范围筛选的示例代码
2019/08/26 Python
一位农村小子的自荐信
2014/04/07 职场文书
外联部演讲稿
2014/05/24 职场文书
商务专员岗位职责范本
2014/06/29 职场文书
民政局副局长民主生活会个人整改措施
2014/10/04 职场文书
2014年爱国卫生工作总结
2014/11/22 职场文书
CSS 使用 resize 实现图片拖拽切换预览功能(强大功能)
2021/08/23 HTML / CSS
如何解决php-fpm启动不了问题
2021/11/17 PHP
spring 项目实现限流方法示例
2022/07/15 Java/Android