91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

基于angular?material?theming機制如何修改mat-toolbar的背景色

發布時間:2022-10-22 14:36:18 來源:億速云 閱讀:226 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“基于angular material theming機制如何修改mat-toolbar的背景色”,內容詳細,步驟清晰,細節處理妥當,希望這篇“基于angular material theming機制如何修改mat-toolbar的背景色”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

首先通過 mat-toolbar (以下統一稱為 toolbar)的實現源代碼 _toolbar-theme.scss 得知背景色來自 theme 中 background palette 的 app-bar

background: theming.get-color-from-palette($background, app-bar);

于是通過下面的 scss 代碼修改 app-bar 的顏色值

$app-bar-background: map-get(mat.$grey-palette, 900);
$background-palette: map-get($theme, background);
$background-palette: map-merge($background-palette, (app-bar: $app-bar-background));
$theme: map-merge($theme, (background: $background-palette));

注:第1行代碼就是我們想使用的背景色

但發現上面的修改對 toolbar 沒有起作用,而通過下面的代碼可以拿到修改后的背景色

$background-palette: map-get($theme, background);
background-color: mat.get-color-from-palette($background-palette, app-bar);

看來 mat-toolbar 不是通過 theme 的 background 獲取背景色的。

查看的 define-light-theme 的實現源碼 _theming.scss 發現下面的代碼

@if $accent != null {
    @warn $_legacy-theme-warning;
    @return private-create-backwards-compatibility-theme(_mat-validate-theme((
      _is-legacy-theme: true,
      color: _mat-create-light-color-config($primary, $accent, $warn),
    )));
  }

由此猜測 toolbar 可能是 legacy theme

進一步查看 toolbar 的實現源碼 _toolbar-theme.scss

@mixin theme($theme-or-color-config) {
  $theme: theming.private-legacy-get-theme($theme-or-color-config);
  @include theming.private-check-duplicate-theme-styles($theme, 'mat-toolbar') {
    $color: theming.get-color-config($theme);
    $density: theming.get-density-config($theme);
    $typography: theming.get-typography-config($theme);
    // ...
  }
}

的確是 legacy theme 。

最終在之前的代碼基礎上添加下面的代碼解決了問題。

$color-palette: map-get($theme, color);
$color-background-palette: map-get($color-palette, background);
$color-background-palette: map-merge($color-background-palette, (app-bar: $app-bar-background));
$color-palette: map-merge($color-palette, (background: $color-background-palette));
$theme: map-merge($theme, (color: $color-palette));

讀到這里,這篇“基于angular material theming機制如何修改mat-toolbar的背景色”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兰溪市| 开封县| 望城县| 万州区| 化德县| 望都县| 西乌| 舟曲县| 石首市| 车致| 渭南市| 三原县| 东至县| 洛隆县| 瓦房店市| 海阳市| 远安县| 正阳县| 大理市| 平阳县| 大邑县| 吉木萨尔县| 新巴尔虎左旗| 尼木县| 乌兰县| 阳新县| 乌苏市| 鹤岗市| 怀安县| 弋阳县| 虞城县| 常州市| 湖北省| 孟村| 临泉县| 荣成市| 巨野县| 商丘市| 奉化市| 桃江县| 黔江区|