[React] {svg, css module, sass} support in Create React App 2.0

Posted Answer1215

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[React] {svg, css module, sass} support in Create React App 2.0相关的知识,希望对你有一定的参考价值。

create-react-app version 2.0 added a lot of new features.

 

One of the new features is added the svgr webpack loader to wrap SVGs in React components as a named export. This let’s you either grab the filename from the default export or grab a wrapped SVG component depending on your needs.

 

Second of the new features is support for Sass. If you start to use Sass, create-react-app will give you an error, but will give detailed instructions on how you can add Sass support to your project.

 

Thrid features is to add CSS Module support. CSS Modules automatically scope class names and animation names local by default to get around the problem of global name clashes. You can learn more by looking at the CSS Modules repository.

 

import React, {Component} from \'react\';
// ReactComponent support svg
import logo, {
    ReactComponent as ReactLogo
} from "./logo.svg";
import \'./App.scss\';
// Supoort
import styles from \'./styles.module.css\';

class App extends Component {
    render() {
        return (
            <div className="App">
                <header className="App-header">
                    <!-- Using svg -->
                    <ReactLogo className="App-logo-svg" alt="logo"/>
                    <img src={logo} className="App-logo" alt="logo"/>
                    <p>
                        Edit <code>src/App.js</code> and save to reload.
                    </p>
                    <a
                        className="App-link"
                        href="https://reactjs.org"
                        target="_blank"
                        rel="noopener noreferrer"
                    >
                        Learn React
                    </a>
                    <!-- Using css module -->
                    <a
                        className={styles[\'error\']}
                        href="https://reactjs.org"
                        target="_blank"
                        rel="noopener noreferrer"
                    >
                        Learn React
                    </a>
                </header>
            </div>
        );
    }
}

export default App;

 

App.scss:

.App-logo-svg {
  height: 40vmin;
  & g {
    fill: salmon;
  }

  & path {
    stroke: palegoldenrod;
    fill: none;
    stroke-width: 10px;
    stroke-dasharray: 35px 15px;
    animation: orbit 1s infinite linear;
  }
}

@keyframes orbit { to { stroke-dashoffset: 50px; } }

 

styles.module.css:

.warning {
    color: black;
    background-color: yellow;
}

.error {
    color: white;
    background-color: red;
}

 

以上是关于[React] {svg, css module, sass} support in Create React App 2.0的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 React 设置 babel-plugin-react-css-modules?

CSS modules 与 React中实践

CSS module和React 中的应用

react-css-modules 无法正常工作

create-react-app中css module无效的解决办法

Module.css 在 React 中不起作用。因此 css 也无法继续。请回复