首頁 web前端 css教學 react中使用css的七種方法介紹(附程式碼)

react中使用css的七種方法介紹(附程式碼)

Mar 30, 2019 am 11:44 AM
css3 react.js scss

這篇文章帶給大家的內容是關於react中使用css的七種方法介紹(附程式碼),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

第一種: 在元件中直接使用style

不需要元件從外部引入css文件,直接在元件中書寫。

import React, { Component } from "react";

const div1 = {
  width: "300px",
  margin: "30px auto",
  backgroundColor: "#44014C",  //驼峰法
  minHeight: "200px",
  boxSizing: "border-box"
};

class Test extends Component {
  constructor(props, context) {
    super(props);
  }
 
  render() {
    return (
     <div>
       <div>123</div>
       <div>
     </div>
    );
  }
}

export default Test;<p>注意事項:<br>1.在正常的css中,例如background-color,box-sizing等屬性,在style物件p1中的屬性中,必須轉換成駝峰法,backgroundColor,boxSizing 。而沒有連字符的屬性,如margin,width等,則在style物件中不變。 <br>2.在正常的css中,css的值不需要用雙重引好(""),如</p>
<pre class="brush:php;toolbar:false">.App-header {
  background-color: #282c34;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-size: calc(10px + 2vmin);
  color: white;
}
登入後複製

3.不能直接使用字串寫style,會報錯

<div>
<p><img src="/static/imghw/default1.png" data-src="https://img.php.cn/upload/image/171/466/819/1553917250154517.png" class="lazy" title="1553917250154517.png" alt="react中使用css的七種方法介紹(附程式碼)"></p>
<p>而在rea​​ct中使用style物件的方式時。值必須用雙引號包裹起來。 </p>
<p>這種方式的react樣式,只作用於目前元件。 </p>
<p style="white-space: normal;">第二種: 在元件中引入[name].css檔案</p>
<p>需要在目前元件開頭使用import引入css檔案。 </p>
<pre class="brush:php;toolbar:false">import React, { Component } from "react";
import TestChidren from "./TestChidren";
import "@/assets/css/index.css";

class Test extends Component {
  constructor(props, context) {
    super(props);
  }
 
  render() {
    return (
      <div>
        <div>123</div>
        <testchidren>测试子组件的样式</testchidren>
      </div>

    );
  }
}

export default Test;
登入後複製

這種方式引入的css樣式,會作用於目前元件及其所有後代元件。

第三種: 3、在元件中引入[name].scss文件

#react內部已經支援了後綴為scss的文件,所以只需要安裝node -sass即可,因為有了node-sass,scss檔才能在node環境上編譯成css檔。

>yarn add node-sass
登入後複製

然後寫scss檔

//index.scss
.App{
  background-color: #282c34;
  .header{
    min-height: 100vh;
    color: white;
  }
}
登入後複製

關於如何詳細的使用sass,請查看sass官網

這種方式引入的css樣式,同樣會作用於當前組件及其所有後代組件

第四種: 在元件中引入[name].module.css檔案

#將css檔案引入,這個模組中的所有css,只作用於當前組件。不會影響目前組件的後代組件。

import React, { Component } from "react";
import TestChild from "./TestChild";
import moduleCss from "./test.module.css";

class Test extends Component {
  constructor(props, context) {
    super(props);
  }  
 
  render() {
    return (
     <div>
       <div>321321</div>
       <testchild></testchild>
     </div>
    );
  }
}

export default Test;
登入後複製

這種方式可以看做是前面第一個在元件中使用style的升級版。完全將css和元件分離開,又不會影響其他元件。

第五種: 在元件中引入[name].module.scss檔

#類似於第四種,差異是第四種引入css module,而這種是引入scss module而已。

import React, { Component } from "react";
import TestChild from "./TestChild";
import moduleCss from "./test.module.scss";

class Test extends Component {
  constructor(props, context) {
    super(props);
  }  
 
  render() {
    return (
     <div>
       <div>321321</div>
       <testchild></testchild>
     </div>
    );
  }
}

export default Test;
登入後複製

同樣這種方式可以看做是前面第一種在元件中使用style的升級版。

第六種: 使用styled-components

需要先安裝

>yarn add styled-components
登入後複製

然後建立一個js檔案(注意是js文件,不是css文件)

//style.js
import styled, { createGlobalStyle } from "styled-components";

export const SelfLink = styled.p`
  height: 50px;
  border: 1px solid red;
  color: yellow;
`;

export const SelfButton = styled.p`
  height: 150px;
  width: 150px;
  color: ${props => props.color};
  background-image: url(${props => props.src});
  background-size: 150px 150px;
`;
登入後複製

元件中使用styled-components樣式

import React, { Component } from "react";

import { SelfLink, SelfButton } from "./style";

class Test extends Component {
  constructor(props, context) {
    super(props);
  }  
 
  render() {
    return (
     <div>
       <selflink>app.js</selflink>
       <selfbutton>
          SelfButton
        </selfbutton>
     </div>
    );
  }
}

export default Test;
登入後複製

這種方式是將整個css樣式,和html節點整體合併成一個元件。引入這個元件html和css都有了。
它的好處是可以隨時透過往元件上傳入 屬性,來動態的改變樣式。對於處理變數、媒體查詢、偽類等較方便的。

這種方式的css也只對目前元件有效。

特定用法,請查看styled-components官網

第七種: 使用radium

需要先安裝

>yarn add radium
登入後複製

然後在react元件中直接引入使用

import React, { Component } from "react";
import Radium from 'radium';

let styles = {
  base: {
    color: '#fff',
    ':hover': {
      background: '#0074d9'
    }
  },
  primary: {
    background: '#0074D9'
  },
  warning: {
    background: '#FF4136'
  }
};

class Test extends Component {
  constructor(props, context) {
    super(props);
  }  
 
  render() {
    return (
     <div>
      <button>
        this is a primary button
      </button>
     </div>
    );
  }
}

export default Radium(Test);
登入後複製

對於處理變數、媒體查詢、偽類別等是不方便的。

使用Radium可以直接處理變數、媒體查詢、偽類別等,並且可以直接使用js中的數學,連接,正規表達式,條件,函數等。

具體用法請看radium官網

注意:在export之前,必須用Radium包裹。

這篇文章到這裡就已經全部結束了,更多其他精彩內容可以關注PHP中文網的CSS影片教學專欄!

#

以上是react中使用css的七種方法介紹(附程式碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

純CSS3怎麼實現波浪效果? (程式碼範例) 純CSS3怎麼實現波浪效果? (程式碼範例) Jun 28, 2022 pm 01:39 PM

純CSS3怎麼實現波浪效果?這篇文章就來跟大家介紹一下使用 SVG 和 CSS 動畫來製作波浪效果的方法,希望對大家有幫助!

React父元件怎麼呼叫子元件的方法 React父元件怎麼呼叫子元件的方法 Dec 27, 2022 pm 07:01 PM

呼叫方法:1、類別元件中的呼叫可以利用React.createRef()、ref的函數式宣告或props自訂onRef屬性來實作;2、函式元件、Hook元件中的呼叫可以利用useImperativeHandle或forwardRef拋出子組件ref來實作。

巧用CSS實現各種奇形怪狀按鈕(附代碼) 巧用CSS實現各種奇形怪狀按鈕(附代碼) Jul 19, 2022 am 11:28 AM

這篇文章帶大家看看怎麼使用 CSS 輕鬆實現高頻出現的各類奇形怪狀按鈕,希望對大家有幫助!

css怎麼隱藏元素但不佔空間 css怎麼隱藏元素但不佔空間 Jun 01, 2022 pm 07:15 PM

兩種方法:1、利用display屬性,只要為元素加上「display:none;」樣式即可。 2.利用position和top屬性設定元素絕對定位來隱藏元素,只需為元素加上「position:absolute;top:-9999px;」樣式。

css3怎麼實現花邊邊框 css3怎麼實現花邊邊框 Sep 16, 2022 pm 07:11 PM

在css中,可以利用border-image屬性來實作花邊邊框。 border-image屬性可以使用圖片來建立邊框,即給邊框加上背景圖片,只需要將背景圖片指定為花邊樣式即可;語法「border-image: url(圖片路徑) 向內偏移值圖像邊界寬度outset 是否重複;」。

原來利用純CSS也能實現文字輪播與圖片輪播! 原來利用純CSS也能實現文字輪播與圖片輪播! Jun 10, 2022 pm 01:00 PM

怎麼製作文字輪播與圖片輪播?大家第一想到的是利用js,其實利用純CSS也能實現文字輪播與圖片輪播,下面來看看實作方法,希望對大家有幫助!

css3如何實現滑鼠點擊圖片放大 css3如何實現滑鼠點擊圖片放大 Apr 25, 2022 pm 04:52 PM

實作方法:1、使用「:active」選擇器選取滑鼠點擊圖片的狀態;2、使用transform屬性和scale()函數實現圖片放大效果,語法「img:active {transform: scale(x軸放大倍率,y軸放大倍率);}」。

css3怎麼設定動畫旋轉速度 css3怎麼設定動畫旋轉速度 Apr 28, 2022 pm 04:32 PM

在css3中,可以利用「animation-timing-function」屬性來設定動畫旋轉速度,該屬性用於指定動畫將如何完成一個週期,設定動畫的速度曲線,語法為「元素{animation-timing-function:速度屬性值;}」。

See all articles