」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何使用 @content 和 @at-root 在 SCSS/CSS 中建立佔位符 Mixin?

如何使用 @content 和 @at-root 在 SCSS/CSS 中建立佔位符 Mixin?

發佈於2024-11-19
瀏覽:558

How to Create a Placeholder Mixin in SCSS/CSS Using @content and @at-root?

SCSS/CSS 中的佔位混合

由於傳入的CSS 屬性中存在冒號和分號,您在Sass 中建立佔位混合時遇到問題mixin.

要克服這一挑戰,請在您的mixin:

@mixin placeholder {
  ::-webkit-input-placeholder {@content}
  :-moz-placeholder           {@content}
  ::-moz-placeholder          {@content}
  :-ms-input-placeholder      {@content}  
}

您現在可以包含 mixin,如下所示:

@include placeholder {
    font-style: italic;
    color: white;
    font-weight: 100;
}

此外,Sass 3.4 引入了@at-root 指令,使您能夠以在嵌套和非嵌套上下文中都有效的方式編寫mixin:

@mixin placeholder {
  @include optional-at-root('::-webkit-input-placeholder') {
    @content;
  }

  @include optional-at-root(':-moz-placeholder') {
    @content;
  }

  @include optional-at-root('::-moz-placeholder') {
    @content;
  }

  @include optional-at-root(':-ms-input-placeholder') {
    @content;
  }
}

透過將 @at-root 與 @content 結合使用,您可以確保您的 mixin 在所有情況下都能正常運作。

最新教學 更多>
  • 如何從 MySQL 轉儲中刪除 DEFINER 子句:增強備份安全性和可移植性指南
    如何從 MySQL 轉儲中刪除 DEFINER 子句:增強備份安全性和可移植性指南
    從MySQL 轉儲中刪除DEFINER 子句從MySQL 轉儲中刪除DEFINER 子句MySQL 轉儲可能包含DEFINER 子句,它指定建立要轉儲的資料庫對象的使用者和主機。將轉儲匯入到不同環境時,這些子句可能會造成安全性問題或導致衝突。 為了緩解這些問題,通常需要從轉儲檔案中刪除 DEFINE...
    程式設計 發佈於2024-11-19
  • 儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    解決PHP 中的POST 請求故障在提供的程式碼片段中:action=''而非:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"檢查$_POST陣列:表單提交後使用 var_dump 檢查 $_POST 陣列的內...
    程式設計 發佈於2024-11-19
  • 為什麼編譯器優化 lambda 函數比傳統函數更有效?
    為什麼編譯器優化 lambda 函數比傳統函數更有效?
    Lambda 優化和內聯函數:編譯器的優勢Nicolai Josuttis 的聲明(與普通函數相比,lambda 表現出卓越的編譯器優化)引起了許多人的興趣開發人員。透過調查這項說法,我們試圖揭示這種優化優勢背後的根本原因。 函數物件和內聯作為函數物件的Lambda 擁有一個關鍵優勢:將它們傳遞給函...
    程式設計 發佈於2024-11-19
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-19
  • PHP 的 time() 函數傳回與時區無關的時間戳記嗎?
    PHP 的 time() 函數傳回與時區無關的時間戳記嗎?
    PHP time() 傳回與時區無關的時間戳記嗎? 處理時間計算時,了解以下內容的上下文非常重要時間戳以及時區如何影響它。 PHP 的 time() 函數提供了時間戳記值,但其時區意義需要澄清。 GMT/UTC 時間戳UTC(協調世界時)和 GMT(格林威治)平均時間)是用作測量世界時間基礎的時區。...
    程式設計 發佈於2024-11-19
  • 如何有效率地檢索 Go 字串的最後一個字元?
    如何有效率地檢索 Go 字串的最後一個字元?
    檢索Go 字符串的最後一個字符在Go 中,處理字符串時會出現一個常見的需求:從Go 字符串中檢索最後X 個字元給定的字串。雖然 string 套件沒有為此任務提供特定函數,但有一些有效的方法可以使用切片表達式來完成此任務。 要取得字串的最後 N 個字符,請使用以下切片表達式語法:stringVari...
    程式設計 發佈於2024-11-19
  • 渲染後如何在 React 中聚焦輸入欄位?
    渲染後如何在 React 中聚焦輸入欄位?
    React渲染後對輸入字段進行聚焦在React中,渲染後對輸入字段設置焦點可以通過多種方法實現. 一種方法是使用文件中建議的引用。透過將 ref 指派給渲染函數中的輸入欄位(例如「nameInput」),您可以存取其 DOM 節點並手動呼叫 focus 方法。然而,了解何時何地呼叫該函數至關重要。 ...
    程式設計 發佈於2024-11-19
  • 由於來源凍結期導致 AWS DMS 表格失敗
    由於來源凍結期導致 AWS DMS 表格失敗
    我們正在將 AWS DMS 與 db2 連接以遷移資料。在來源中,我們有大約 8 小時的凍結期,因此我們將停止並恢復 DMS 服務。 一旦我們恢復 DMS,大多數表將恢復,但某些表仍將被鎖定,因為某些更改會導致“表錯誤”狀態。此後我們無法恢復表,唯一的選項是重新載入。 我們無法定義牌桌清單或這些...
    程式設計 發佈於2024-11-19
  • 如何在 PHP Script Echo 中處理雙引號?
    如何在 PHP Script Echo 中處理雙引號?
    PHP 腳本 Echo 中的雙引號在 PHP 腳本中回顯 HTML 程式碼時,正確處理雙引號至關重要。考慮以下範例:<?php echo "<script>$('#edit_errors').html('<h3'><em>Please Correc...
    程式設計 發佈於2024-11-19
  • 如何使用正規表示式驗證電子郵件地址:語法與完整驗證?
    如何使用正規表示式驗證電子郵件地址:語法與完整驗證?
    如何使用正規表示式驗證電子郵件地址透過表單收集使用者輸入時,確保提供的電子郵件地址有效至關重要。正規表示式 (regex) 提供了執行此驗證的便捷方法。然而,僅驗證語法是不夠的。 語法驗證要執行基本語法驗證,可以使用以下正規表示式模式:[^@] @[^@] \.[^@] 此模式檢視以下內容標準:剛好...
    程式設計 發佈於2024-11-19
  • 為什麼我們要在程式退出之前呼叫 C++ 中的「delete」?
    為什麼我們要在程式退出之前呼叫 C++ 中的「delete」?
    為什麼在程式退出之前在C中呼叫delete? 在C中,在程式終止之前明確調用堆分配記憶體的delete是很重要的。如果不這樣做,可能會導致記憶體洩漏和不可靠的應用程式行為。 程式退出時的記憶體釋放雖然大多數作業系統在程式退出時自動回收堆內存,僅依賴這種預設行為可能會出現問題。造成這種情況的主要原因有...
    程式設計 發佈於2024-11-19
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1 和 $array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建...
    程式設計 發佈於2024-11-19
  • ::content 偽元素如何在 Shadow DOM 中啟用深度樣式?
    ::content 偽元素如何在 Shadow DOM 中啟用深度樣式?
    揭開Shadow DOM 中的::content/:slotted 偽元素Shadow DOM 是Web 元件的一個關鍵方面,它引入了一種封裝和分離內容的新穎方法。在此領域中,::content(以前稱為 ::slotted)偽元素在啟用 ShadowTree 內的分散式節點的深層樣式方面發揮關鍵作...
    程式設計 發佈於2024-11-19
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-19
  • 如何在 InnoDB 中鎖定不存在的行:困境和解決方案
    如何在 InnoDB 中鎖定不存在的行:困境和解決方案
    鎖定不存在的 InnoDB 行:技術困境在資料庫管理領域,通常需要確保操作以原子方式執行,防止任何衝突或不一致。在處理可能嘗試修改相同資料的並發事務時尤其如此。在本文中,我們解決了一個需要鎖定不存在的 InnoDB 行的特定場景。 提出的問題是:如何確定資料庫中不存在使用者名,然後將其插入為一個新行...
    程式設計 發佈於2024-11-19

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3