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
  • 就像 Web Api 介面可以對入參進行驗證,避免用戶傳入非法的或者不符合我們預期的參數一樣,選項也可以對配置源的內容進行驗證,避免配置中的值與選項類中的屬性不對應或者不滿足預期,畢竟大部分配置都是通過字元串的方式,驗證是很有必要的。 1. 註解驗證 像入參驗證一樣,選項驗證也可以通過特性註解方便地 ...
  • 原文作者:aircraft 原文鏈接:https://www.cnblogs.com/DOMLX/p/17270107.html 加工的泛型類如下: using System; using System.Collections.Generic; using System.IO; using Syst ...
  • 在前一篇文章,我們瞭解瞭如何通過.NET6+Quartz開發基於控制台應用程式的定時任務,今天繼續在之前的基礎上,進一步講解基於ASP.NET Core MVC+Quartz實現定時任務的可視化管理頁面,僅供學習分享使用,如有不足之處,還請指正。 涉及知識點 Quartz組件,關於Quartz組件的 ...
  • 面向對象1 面向對象,更在乎的結果,而過程的實現並不重要 IDea快捷鍵(基礎版) | 快捷鍵 | 作用 | | | | | ctrl + / | 快捷註釋 | | ctrl + shift + / | 多行註釋 | | ctrl + d | 快速複製 | | ctrl + shift + up/d ...
  • NX中的checkmate功能是用於檢查模型、圖紙數據的工具,在UGOPEN中有例子。手動操作可以檢查已載入的裝配下所有零部件,可以設置通過後保存模型,檢查結果保存到Teamcenter中,預設保存在零組件版本下。 代碼中可以設置多個檢查規則。相關設置可以在用戶預設設置中進行設置。 1 // 2 / ...
  • JavaSE 運算符 算術運算符:+,-,*,/,%,++(自增),--(自減) i++:先用後+1;++i:先+1後用 賦值運算符:= 擴展賦值運算符:+=,-=,*=,/= a+=b >a=a+b: ​ 可讀性差,但是編譯效率高,且會自動進行類型轉換; ​ 當ab為基本數據類型時,a+b和b+a ...
  • 面向對象2 訪問修飾符 | | private | default | protected | public | | | | | | | | 當前類 | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_che ...
  • 推薦一些學習qml教程 Qt官方的QML教程: https://doc.qt.io/qt-5/qtqml-index.html 這是一個由Qt官方提供的完整的QML教程,包含了所有基本知識和高級語法。 QML中文網:http://www.qmlcn.com/ 這是一個非常不錯的中文QML學習網站,提 ...
  • QAbstractBUtton: 所有按鈕控制項的基類 提供按鈕的通用功能 繼承自QWidget 屬於抽象類別,不能直接去使用,必須藉助於子類(除非你覺得子類不夠用,想自定義一個按鈕) 大部分功能之前已經使用過,在這裡只作簡單介紹 文本設置: setText(str) :設置按鈕提示文本 text() ...
  • 使用 VLD 記憶體泄漏檢測工具輔助開發時整理的學習筆記。本篇介紹 VLD 配置文件中配置項 StartDisabled 的使用方法。 ...