react使用sass

来源:https://www.cnblogs.com/sunyan97/archive/2022/09/21/16715974.html
-Advertisement-
Play Games

1. 安裝sass 較新的版本不需要配置sass-loader等一系列插件,安裝即用。 npm install --save-dev sass 2. 編寫App.tsx中的基本DOM 更改app.css為app.scss,並刪除其中全部內容 使用如下代碼替換app.tsx中的內容 import ". ...


1. 安裝sass

較新的版本不需要配置sass-loader等一系列插件,安裝即用。

npm install --save-dev sass

2. 編寫App.tsx中的基本DOM

更改app.css為app.scss,並刪除其中全部內容
使用如下代碼替換app.tsx中的內容

import "./App.scss";

function App() {
  return (
    <div className="App">
      <div className="header">
        <ul>
          <li>導航1</li>
          <li>導航2</li>
          <li>導航3</li>
        </ul>
      </div>
      <div className="container">
        <div className="con_Item1">測試混入的內容</div>
        <div className="con_Item2">測試傳參混入</div>
        <div className="con_Item3">剩餘參數混入</div>
        <div className="con_Item4">瀏覽器首碼混入</div>
        <div style={{marginTop:20}}>
          <div className="baseBtn">基類</div>
          <div className="reportBtn">繼承1</div>
          <div className="submitBtn">繼承2</div>
        </div>
      </div>
      <div className="footer">頁腳</div>
    </div>
  );
}

export default App;

3. sass變數

sass變數使用$符號開頭 可以存儲字元串、數字、顏色值、布爾值、列表、null。

下方定義了 若幹個sass變數:

$maxWidth: 100%;
$maxHeight: 100%;
$myColor: red;
$myFont: Helvetica, sans-serif;
$myFontSize: 20px;
$headerHight: 49px;

//使用
body,
html {
  width: $maxWidth;
  height: $maxHeight;
  margin: 0;
  padding: 0;
}
#root {
  width: $maxWidth;
  height: $maxHeight;
}
.App {
  width: $maxWidth;
  height: $maxHeight;
  display: flex;
  flex-direction: column;
}

sass變數只能作用於當前的層級:

$myColor:red;

p{
    $myColor:green; //只在p中有效果
    color:$myColor; //為綠色
}
span{
    color:$myColor;//為紅色
}

4. sass中的選擇器嵌套和屬性嵌套

選擇器嵌套

.header {
  width: $maxWidth;
  height: $headerHight;
  background-color: gold;

  ul {
    margin: 0;
    padding: 0;
    height: $maxHeight;
    list-style: none;
    display: flex;
    justify-content: space-around;
  }
  li {
    display: block;
    flex: 1;
    height: 100%;
    line-height: $headerHight;
    background-color: gold;
  }
}

屬性嵌套
很多 CSS 屬性都有同樣的首碼,例如:font-family, font-size 和 font-weight , text-align, text-transform 和 text-overflow。

在 Sass 中,我們可以使用嵌套屬性來編寫它們:

//屬性嵌套
font: {
    family: $myFont;
    size: $myFontSize;
    weight: bold;
}
text: {
    align: center;
    transform: lowercase;
    overflow: hidden;
}

5. sass中的@import和Partials

@import可以讓我們導入其他文件中的內容
包含文件時不需要指定文件尾碼,Sass 會自動添加尾碼 .scss。

此外,你也可以導入 CSS 文件。

導入後我們就可以在主文件中使用導入文件等變數。

如在app.scss中導入 :

@import "reset";

reset.scss中的樣式會被編譯到app.scss中

Sass Partials

如果你不希望將一個 Sass 的代碼文件編譯到一個 CSS 文件,你可以在文件名的開頭添加一個下劃線。這將告訴 Sass 不要將其編譯到 CSS 文件。

但是,在導入語句中我們不需要添加下劃線。

我們可以將之前定義的變數抽取出來,粘貼到新建的_globals.scss中

$maxWidth: 100%;
$maxHeight: 100%;
$myColor: red;
$myFont: Helvetica, sans-serif;
$myFontSize: 20px;
$headerHight: 49px;

然後再app.scss中引入:

@import "./assets/globals";

#root {
  width: $maxWidth;
  height: $maxHeight;
}

註意:請不要將帶下劃線不帶下劃線的同名文件放置在同一個目錄下,比如,_colors.scss 和 colors.scss 不能同時存在於同一個目錄下,否則帶下劃線的文件將會被忽略。

6. Sass中的 @mixin 與 @include

@mixin 指令允許我們定義一個可以在整個樣式表中重覆使用的樣式。

@include 指令可以將混入(mixin)引入到文檔中。

_globals.scss

//sass 混入
@mixin important-redBgWhiteFt {
  margin: 10px 0;
  height: 50px;
  line-height: 50px;
  text-align: center;
  background-color: red;
  color: white;
  border: 3px solid green;
}
//接收參數的混入
@mixin borderInvert($color: white, $width: 2px) {
  border: $width solid $color;
}
//剩餘參數混入
@mixin box-shadow($shadows...) {
  -moz-box-shadow: $shadows;
  -webkit-box-shadow: $shadows;
  box-shadow: $shadows;
}
//瀏覽器首碼使用混入
@mixin transformMix($data) {
    -webkit-transform: $data;
    -ms-transform: $data;
    transform: $data;
}

使用:

app.scss

//包含基礎混入
.con_Item1 {
  //sass包含
  @include important-redBgWhiteFt;
  border-radius: 5px;
}
//包含帶參數的混入
.con_Item2 {
  //sass包含
  @include borderInvert(blue, 5px);
  height: 50px;
  background-color: green;
}
//包含剩餘參數的混入
.con_Item3 {
  margin-top: 10px;
  height: 50px;
  @include box-shadow(0px 4px 5px #666, 2px 6px 10px #999);
}
//包含瀏覽器首碼的混入
.con_Item4 {
  @include borderInvert(gold, 2px);
  @include transformMix(rotate(180deg));
  margin-top: 10px;
  height: 50px;
}

7.sass中的繼承 @extend

@extend 指令告訴 Sass 一個選擇器的樣式從另一選擇器繼承。

如果一個樣式與另外一個樣式幾乎相同,只有少量的區別,則使用 @extend 就顯得很有用。

//樣式繼承
//被繼承的基類
.baseBtn {
  @include borderInvert(blue, 1px);
  margin-top: 20px;
  display: block;
  width: 80px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  cursor: pointer;
  
  &:hover{
    background-color: gray;
  }
}
//繼承基礎樣式的按鈕1
.reportBtn{
  @extend .baseBtn;
  background-color: red;
}
//繼承基礎樣式的按鈕2
.submitBtn{
  @extend .baseBtn;
  border-radius: 5px;
}

8. 源代碼

app.tsx:

import "./App.scss";

function App() {
  return (
    <div className="App">
      <div className="header">
        <ul>
          <li>導航1</li>
          <li>導航2</li>
          <li>導航3</li>
        </ul>
      </div>
      <div className="container">
        <div className="con_Item1">測試混入的內容</div>
        <div className="con_Item2">測試傳參混入</div>
        <div className="con_Item3">剩餘參數混入</div>
        <div className="con_Item4">瀏覽器首碼混入</div>
        <div style={{marginTop:20}}>
          <div className="baseBtn">基類</div>
          <div className="reportBtn">繼承1</div>
          <div className="submitBtn">繼承2</div>
        </div>
      </div>
      <div className="footer">頁腳</div>
    </div>
  );
}

export default App;

_globals.scss:

$maxWidth: 100%;
$maxHeight: 100%;
$myColor: red;
$myFont: Helvetica, sans-serif;
$myFontSize: 20px;
$headerHight: 49px;

//sass 混入
@mixin important-redBgWhiteFt {
  margin: 10px 0;
  height: 50px;
  line-height: 50px;
  text-align: center;
  background-color: red;
  color: white;
  border: 3px solid green;
}
//接收參數的混入
@mixin borderInvert($color: white, $width: 2px) {
  border: $width solid $color;
}
//剩餘參數混入
@mixin box-shadow($shadows...) {
  -moz-box-shadow: $shadows;
  -webkit-box-shadow: $shadows;
  box-shadow: $shadows;
}
//瀏覽器首碼使用混入
@mixin transformMix($data) {
    -webkit-transform: $data;
    -ms-transform: $data;
    transform: $data;
}

app.scss:

@import "./assets/globals";

body,
html {
  width: $maxWidth;
  height: $maxHeight;
  margin: 0;
  padding: 0;
}
#root {
  width: $maxWidth;
  height: $maxHeight;
}
.App {
  width: $maxWidth;
  height: $maxHeight;
  display: flex;
  flex-direction: column;
}

// 選擇器嵌套
.header {
  width: $maxWidth;
  height: $headerHight;
  background-color: gold;

  ul {
    margin: 0;
    padding: 0;
    height: $maxHeight;
    list-style: none;
    display: flex;
    justify-content: space-around;
  }
  li {
    display: block;
    flex: 1;
    height: 100%;
    line-height: $headerHight;
    background-color: gold;

    //屬性嵌套
    font: {
      family: $myFont;
      size: $myFontSize;
      weight: bold;
    }
    text: {
      align: center;
      transform: lowercase;
      overflow: hidden;
    }
  }
}

.container {
  flex: 1;
  background-color: pink;
}
//包含基礎混入
.con_Item1 {
  //sass包含
  @include important-redBgWhiteFt;
  border-radius: 5px;
}
//包含帶參數的混入
.con_Item2 {
  //sass包含
  @include borderInvert(blue, 5px);
  height: 50px;
  background-color: green;
}
//包含剩餘參數的混入
.con_Item3 {
  margin-top: 10px;
  height: 50px;
  @include box-shadow(0px 4px 5px #666, 2px 6px 10px #999);
}
//包含瀏覽器首碼的混入
.con_Item4 {
  @include borderInvert(gold, 2px);
  @include transformMix(rotate(180deg));
  margin-top: 10px;
  height: 50px;
}

//樣式繼承
//被繼承的基類
.baseBtn {
  @include borderInvert(blue, 1px);
  margin-top: 20px;
  display: block;
  width: 80px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  cursor: pointer;
  
  &:hover{
    background-color: gray;
  }
}
//繼承基礎樣式的按鈕1
.reportBtn{
  @extend .baseBtn;
  background-color: red;
}
//繼承基礎樣式的按鈕2
.submitBtn{
  @extend .baseBtn;
  border-radius: 5px;
}

.footer {
  width: $maxWidth;
  height: 49px;
  text-align: center;
  line-height: 49px;
}


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 2022年9月2日,日本MIC(総務省)發佈了“電波法施行規則等の一部を改正する省令(令和4年総務省令第59號)”省令,更新了Wi-Fi 6E Band 5頻帶5925 ~ 6425 MHz的技術要求。隔天(9月3日),日本DSP機構發佈了“「6GHz帯小電力データ通信システム」の特性試験方法”,為 ...
  • AU上傳ipa出現下圖紅框提示說明成功上傳,如果App Store後臺沒有出現構建版本, 請登錄 apple賬號對應的郵箱查看反饋,特別留意垃圾郵箱,無論成功還是失敗,apple都會發郵件 一、首先登錄iTunes Connect 後臺、查看ipa構建情況 https://appstoreconne ...
  • 現如今,人們在網上聊天、發帖時越來越愛用表情包,表情包一方面是一種個性化的表達方式,另一方面更能傳達出當下的心理活動,可以說在網路社交中表情包是一個不可或缺的存在。加上近年來元宇宙的興起,3D虛擬形象廣泛應用,用戶可以通過自己的表情來控制虛擬形象的表情,做一系列專屬的表情包,更加生動形象。 那麼,如 ...
  • ##vue+element-ui後臺管理系統模板 前端:基於vue2.0+或3.0+加上element-ui組件框架 後端:springboot+mybatis-plus寫介面 通過Axios調用介面完成數據傳遞 通過router路由完成各頁面的跳轉 ###全局配置 App.vue <templat ...
  • 好家伙,繼續優化, 好家伙,我把我的飛機大戰發給我的小伙伴們玩 期待著略微的贊賞之詞,然後他們用手機打開我的給他們的網址 然後點一下飛機就炸了。 游戲體驗零分 (滑鼠點擊在移動端依舊可以生效) 好了所以我們來優化一下這個觸屏移動事件 由於沒有參考,就去翻文檔了 觸摸事件分三個:touchstart、 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 1. 定義整體結構 先寫出構造函數,將Promise向外暴露 /* 自定義Promise函數模塊:IIFE */ (function (window) { /* Promise構造函數 executor:執行器函數 */ function ...
  • 一.分類 1.1 頁面佈局 首先創建cate的分支 定義基本結構,因為是兩個需要滾動的區域,所以這裡要用到組件 ==scroll== 這個組件如果是y scroll那就要固定高度,x scroll那就要固定寬度 這裡有個問題就是,我們應該把高度限定在整個屏幕高度 這裡用到uniapp一個api == ...
  • 每日3題 1 以下代碼執行後,控制臺中的輸出內容為? class A { static a = "123"; } class B extends A {} console.log(B.a); 2 以下3句語句,哪句是合法的 1.toString(); 1..toString(); 1...toStr ...
一周排行
    -Advertisement-
    Play Games
  • MQTTnet 是一個高性能的MQTT類庫,支持.NET Core和.NET Framework。 MQTTnet 原理: MQTTnet 是一個用於.NET的高性能MQTT類庫,實現了MQTT協議的各個層級,包括連接、會話、發佈/訂閱、QoS(服務質量)等。其原理涉及以下關鍵概念: MqttCli ...
  • 在WPF中,源屬性(Source Property)指的是提供數據的屬性,通常是數據模型或者其他控制項的屬性,而目標屬性(Target Property)則是數據綁定的目標,通常是綁定到控制項的屬性,例如TextBlock的Text屬性。數據綁定將源屬性的值自動更新到目標屬性中。 主要包含以下幾個事件: ...
  • async/await 是 C# 中非同步編程的關鍵特性,它使得非同步代碼編寫更為簡單和直觀。下麵深入詳細描述了 async/await 的使用場景、優點以及一些高級使用方法,並提供了相應的實例源代碼。 使用場景: I/O 操作: 非同步編程特別適用於涉及 I/O 操作(如文件讀寫、網路請求等)的場景。在 ...
  • 使用過office的visio軟體畫圖的小伙伴都知道,畫圖軟體分為兩部分,左側圖形庫,存放各種圖標,右側是一個畫布,將左側圖形庫的圖標控制項拖拽到右側畫布,就會生成一個新的控制項,並且可以自由拖動。那如何在WPF程式中,實現類似的功能呢?今天就以一個簡單的小例子,簡述如何在WPF中實現控制項的拖拽和拖動,... ...
  • 1、Blazor Hybrid簡介 Blazor Hybrid 使開發人員能夠將桌面和移動本機客戶端框架與 .NET 和 Blazor 結合使用。在 Blazor Hybrid 應用中,Razor 組件在設備上是本機運行的。 這些組件通過本地互操作通道呈現到嵌入式 Web 視圖控制項。 組件不在瀏覽器 ...
  • 除了內置的數據集,scikit-learn還提供了隨機樣本的生成器。通過這些生成器函數,可以生成具有特定特性和分佈的隨機數據集,以幫助進行機器學習演算法的研究、測試和比較。 目前,scikit-learn庫(v1.3.0版)中有20個不同的生成樣本的函數。本篇重點介紹其中幾個具有代表性的函數。 1. ...
  • 從0到1,手把手帶你開發截圖工具ScreenCap------002實現通過文件對話框,選擇合適的文件夾,自定義預設的圖片保存位置,簡單易學 ...
  • 每次談到容器的時候,除了Docker之外,都會說起 Kubernetes,那麼什麼是 Kubernetes呢?今天就來一起學快速入門一下 Kubernetes 吧!希望本文對您有所幫助。 Kubernetes,一種用於管理和自動化雲中容器化工作負載的工具。 想象一下你有一個管弦樂隊,將每個音樂家視為 ...
  • 目錄 基本說明 安裝 Nginx 部署 VUE 前端 部署 Django 後端 Django admin 靜態文件(CSS,JS等)丟失的問題 總結 1. 基本說明 本文介紹了在 windows 伺服器下,通過 Nginx 部署 VUE + Django 前後端分離項目。本項目前端運行在 80 埠 ...
  • 從0到1,手把手帶你開發截圖工具ScreenCap------003實現最小化程式到托盤運行,- 為了方便截圖乾凈,實現最小化程式到托盤運行,簡潔,勿擾,實現最小化程式到托盤運行, 實現托盤菜單功能,實現回顯主窗體, 實現托盤開始截屏, 實現氣泡信息提示,實現托盤程式提示,實現托盤退出程式, 封裝完... ...