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
  • 下麵是一個標準的IDistributedCache用例: public class SomeService(IDistributedCache cache) { public async Task<SomeInformation> GetSomeInformationAsync (string na ...
  • 這個庫提供了在啟動期間實例化已註冊的單例,而不是在首次使用它時實例化。 單例通常在首次使用時創建,這可能會導致響應傳入請求的延遲高於平時。在註冊時創建實例有助於防止第一次Request請求的SLA 以往我們要在註冊的時候實例單例可能會這樣寫: //註冊: services.AddSingleton< ...
  • 最近公司的很多項目都要改單點登錄了,不過大部分都還沒敲定,目前立刻要做的就只有一個比較老的項目 先改一個試試手,主要目標就是最短最快實現功能 首先因為要保留原登錄方式,所以頁面上的改動就是在原來登錄頁面下加一個SSO登錄入口 用超鏈接寫的入口,頁面改造後如下圖: 其中超鏈接的 href="Staff ...
  • Like運算符很好用,特別是它所提供的其中*、?這兩種通配符,在Windows文件系統和各類項目中運用非常廣泛。 但Like運算符僅在VB中支持,在C#中,如何實現呢? 以下是關於LikeString的四種實現方式,其中第四種為Regex正則表達式實現,且在.NET Standard 2.0及以上平... ...
  • 一:背景 1. 講故事 前些天有位朋友找到我,說他們的程式記憶體會偶發性暴漲,自己分析了下是非托管記憶體問題,讓我幫忙看下怎麼回事?哈哈,看到這個dump我還是非常有興趣的,居然還有這種游戲幣自助機類型的程式,下次去大玩家看看他們出幣的機器後端是不是C#寫的?由於dump是linux上的程式,剛好win ...
  • 前言 大家好,我是老馬。很高興遇到你。 我們為 java 開發者實現了 java 版本的 nginx https://github.com/houbb/nginx4j 如果你想知道 servlet 如何處理的,可以參考我的另一個項目: 手寫從零實現簡易版 tomcat minicat 手寫 ngin ...
  • 上一次的介紹,主要圍繞如何統一去捕獲異常,以及為每一種異常添加自己的Mapper實現,並且我們知道,當在ExceptionMapper中返回非200的Response,不支持application/json的響應類型,而是寫死的text/plain類型。 Filter為二方包異常手動捕獲 參考:ht ...
  • 大家好,我是R哥。 今天分享一個爽飛了的面試輔導 case: 這個杭州兄弟空窗期 1 個月+,面試了 6 家公司 0 Offer,不知道問題出在哪,難道是杭州的 IT 崩盤了麽? 報名面試輔導後,經過一個多月的輔導打磨,現在成功入職某上市公司,漲薪 30%+,955 工作制,不咋加班,還不捲。 其他 ...
  • 引入依賴 <!--Freemarker wls--> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.30</version> </dependency> ...
  • 你應如何運行程式 互動式命令模式 開始一個互動式會話 一般是在操作系統命令行下輸入python,且不帶任何參數 系統路徑 如果沒有設置系統的PATH環境變數來包括Python的安裝路徑,可能需要機器上Python可執行文件的完整路徑來代替python 運行的位置:代碼位置 不要輸入的內容:提示符和註 ...