【问题标题】:ionic 5 forcing light theme for the browser appionic 5 强制浏览器应用的浅色主题
【发布时间】:2020-07-03 09:36:20
【问题描述】:

我已经构建了这个应用程序https://cvirus.app 并在浏览器上构建和部署。

在 Android 手机上的 chrome 浏览器上,它呈现深色背景(因为默认情况下应用了深色主题)。

无论什么设备什么浏览器,我都想在任何地方强制使用浅色主题。我该怎么做?

在 theme/variables.scss 中评论深色部分不起作用

【问题讨论】:

标签: ionic-framework ionic5


【解决方案1】:

从 Chrome 浏览器 79 版开始,您可以在 CSS prefers-color-sheme 媒体特征值之间进行选择。 Ionic 尊重这一媒体特性并对它的变化做出反应。

要在不更改操作系统偏好和颜色主题的情况下更改它,您需要在 Chrome 开发工具中打开渲染面板:

  1. 打开 Chrome 开发工具。
  2. 在 PC 上按 Crtl+Shift+PCmd+Shift +P 在 Mac 上。
  3. 在命令面板中输入“显示渲染”。
  4. Enter 并选择选项 Drawer | Show rendering,该选项应该已被选中。

渲染抽屉打开。然后在“模拟 CSS 媒体...”选项中,选择您喜欢的配色方案。

【讨论】:

    【解决方案2】:

    你应该在 theme/variables.scss 中注释 ios body 和 md body 类,然后它就会变成 light 模式。

    【讨论】:

    • 有人试过这个吗?专门为 Ionic 5 设计的??我会然后编辑这条评论
    【解决方案3】:

    要解决此问题,您必须转到 src 文件夹中的 theme/variable.scss 并找到

    @media (prefers-color-scheme: dark)
    

    然后从黑暗变为光明。如果你没有修改 variable.scss。它应该在第 79 行。点击查看screenshot of my own code 我希望这会有所帮助。

    【讨论】:

    • 这是最简单的方法。
    • 对我来说是在 theme/global.scss
    • 这应该被标记为正确答案
    • 这是一个可怕的答案,因为现在期望浅色主题的浏览器得到了深色主题。
    【解决方案4】:

    在 ionic 5+ 中只需将prefers-color-scheme: dark 重命名为prefers-color-scheme: darks 然后无论如何它都不会切换到深色主题。

    【讨论】:

      【解决方案5】:

      就我而言,在 theme/variables.scss 中评论深色主题效果很好。

      我在第 70 行评论@media (prefers-color-scheme: dark) { 直到文件结束。 这是我的文件

      // Ionic Variables and Theming. For more info, please see:
      // http://ionicframework.com/docs/theming/
      
      /** Ionic CSS Variables **/
      :root {
        --ion-color-primary                : #633A82;
        --ion-color-primary-rgb            : 99, 58, 130;
        --ion-color-primary-contrast       : #FFFFFF;
        --ion-color-primary-contrast-rgb   : 255, 255, 255;
        --ion-color-primary-shade          : #573372;
        --ion-color-primary-tint           : #734E8F;
      
        --ion-color-secondary              : #72B5B7;
        --ion-color-secondary-rgb          : 114, 181, 183;
        --ion-color-secondary-contrast     : #000000;
        --ion-color-secondary-contrast-rgb : 0, 0, 0;
        --ion-color-secondary-shade        : #649FA1;
        --ion-color-secondary-tint         : #80BCBE;
      
        --ion-color-tertiary               : #F1FCFC;
        --ion-color-tertiary-rgb           : 241, 252, 252;
        --ion-color-tertiary-contrast      : #000000;
        --ion-color-tertiary-contrast-rgb  : 0, 0, 0;
        --ion-color-tertiary-shade         : #D4DEDE;
        --ion-color-tertiary-tint          : #F2FCFC;
      
        --ion-color-success                : #10DC60;
        --ion-color-success-rgb            : 16, 220, 96;
        --ion-color-success-contrast       : #FFFFFF;
        --ion-color-success-contrast-rgb   : 255, 255, 255;
        --ion-color-success-shade          : #0EC254;
        --ion-color-success-tint           : #28E070;
      
        --ion-color-warning                : #FFCE00;
        --ion-color-warning-rgb            : 255, 206, 0;
        --ion-color-warning-contrast       : #FFFFFF;
        --ion-color-warning-contrast-rgb   : 255, 255, 255;
        --ion-color-warning-shade          : #E0B500;
        --ion-color-warning-tint           : #FFD31A;
      
        --ion-color-danger                 : #F04141;
        --ion-color-danger-rgb             : 245, 61, 61;
        --ion-color-danger-contrast        : #FFFFFF;
        --ion-color-danger-contrast-rgb    : 255, 255, 255;
        --ion-color-danger-shade           : #D33939;
        --ion-color-danger-tint            : #F25454;
      
        --ion-color-dark                   : #222428;
        --ion-color-dark-rgb               : 34, 34, 34;
        --ion-color-dark-contrast          : #FFFFFF;
        --ion-color-dark-contrast-rgb      : 255, 255, 255;
        --ion-color-dark-shade             : #1E2023;
        --ion-color-dark-tint              : #383A3E;
      
        --ion-color-medium                 : #989AA2;
        --ion-color-medium-rgb             : 152, 154, 162;
        --ion-color-medium-contrast        : #FFFFFF;
        --ion-color-medium-contrast-rgb    : 255, 255, 255;
        --ion-color-medium-shade           : #86888F;
        --ion-color-medium-tint            : #A2A4AB;
      
        --ion-color-light                  : #F4F5F8;
        --ion-color-light-rgb              : 244, 244, 244;
        --ion-color-light-contrast         : #000000;
        --ion-color-light-contrast-rgb     : 0, 0, 0;
        --ion-color-light-shade            : #D7D8DA;
        --ion-color-light-tint             : #F5F6F9;
      }
      
      //@media (prefers-color-scheme: dark) {
      //  /*
      //   * Dark Colors
      //   * -------------------------------------------
      //   */
      //
      //  body {
      //    --ion-color-primary: #428cff;
      //    --ion-color-primary-rgb: 66,140,255;
      //    --ion-color-primary-contrast: #ffffff;
      //    --ion-color-primary-contrast-rgb: 255,255,255;
      //    --ion-color-primary-shade: #3a7be0;
      //    --ion-color-primary-tint: #5598ff;
      //
      //    --ion-color-secondary: #50c8ff;
      //    --ion-color-secondary-rgb: 80,200,255;
      //    --ion-color-secondary-contrast: #ffffff;
      //    --ion-color-secondary-contrast-rgb: 255,255,255;
      //    --ion-color-secondary-shade: #46b0e0;
      //    --ion-color-secondary-tint: #62ceff;
      //
      //    --ion-color-tertiary: #6a64ff;
      //    --ion-color-tertiary-rgb: 106,100,255;
      //    --ion-color-tertiary-contrast: #ffffff;
      //    --ion-color-tertiary-contrast-rgb: 255,255,255;
      //    --ion-color-tertiary-shade: #5d58e0;
      //    --ion-color-tertiary-tint: #7974ff;
      //
      //    --ion-color-success: #2fdf75;
      //    --ion-color-success-rgb: 47,223,117;
      //    --ion-color-success-contrast: #000000;
      //    --ion-color-success-contrast-rgb: 0,0,0;
      //    --ion-color-success-shade: #29c467;
      //    --ion-color-success-tint: #44e283;
      //
      //    --ion-color-warning: #ffd534;
      //    --ion-color-warning-rgb: 255,213,52;
      //    --ion-color-warning-contrast: #000000;
      //    --ion-color-warning-contrast-rgb: 0,0,0;
      //    --ion-color-warning-shade: #e0bb2e;
      //    --ion-color-warning-tint: #ffd948;
      //
      //    --ion-color-danger: #ff4961;
      //    --ion-color-danger-rgb: 255,73,97;
      //    --ion-color-danger-contrast: #ffffff;
      //    --ion-color-danger-contrast-rgb: 255,255,255;
      //    --ion-color-danger-shade: #e04055;
      //    --ion-color-danger-tint: #ff5b71;
      //
      //    --ion-color-dark: #f4f5f8;
      //    --ion-color-dark-rgb: 244,245,248;
      //    --ion-color-dark-contrast: #000000;
      //    --ion-color-dark-contrast-rgb: 0,0,0;
      //    --ion-color-dark-shade: #d7d8da;
      //    --ion-color-dark-tint: #f5f6f9;
      //
      //    --ion-color-medium: #989aa2;
      //    --ion-color-medium-rgb: 152,154,162;
      //    --ion-color-medium-contrast: #000000;
      //    --ion-color-medium-contrast-rgb: 0,0,0;
      //    --ion-color-medium-shade: #86888f;
      //    --ion-color-medium-tint: #a2a4ab;
      //
      //    --ion-color-light: #222428;
      //    --ion-color-light-rgb: 34,36,40;
      //    --ion-color-light-contrast: #ffffff;
      //    --ion-color-light-contrast-rgb: 255,255,255;
      //    --ion-color-light-shade: #1e2023;
      //    --ion-color-light-tint: #383a3e;
      //  }
      //
      //  /*
      //   * iOS Dark Theme
      //   * -------------------------------------------
      //   */
      //
      //  .ios body {
      //    --ion-background-color: #000000;
      //    --ion-background-color-rgb: 0,0,0;
      //
      //    --ion-text-color: #ffffff;
      //    --ion-text-color-rgb: 255,255,255;
      //
      //    --ion-color-step-50: #0d0d0d;
      //    --ion-color-step-100: #1a1a1a;
      //    --ion-color-step-150: #262626;
      //    --ion-color-step-200: #333333;
      //    --ion-color-step-250: #404040;
      //    --ion-color-step-300: #4d4d4d;
      //    --ion-color-step-350: #595959;
      //    --ion-color-step-400: #666666;
      //    --ion-color-step-450: #737373;
      //    --ion-color-step-500: #808080;
      //    --ion-color-step-550: #8c8c8c;
      //    --ion-color-step-600: #999999;
      //    --ion-color-step-650: #a6a6a6;
      //    --ion-color-step-700: #b3b3b3;
      //    --ion-color-step-750: #bfbfbf;
      //    --ion-color-step-800: #cccccc;
      //    --ion-color-step-850: #d9d9d9;
      //    --ion-color-step-900: #e6e6e6;
      //    --ion-color-step-950: #f2f2f2;
      //
      //    --ion-toolbar-background: #0d0d0d;
      //
      //    --ion-item-background: #1c1c1c;
      //    --ion-item-background-activated: #313131;
      //  }
      //
      //
      //  /*
      //   * Material Design Dark Theme
      //   * -------------------------------------------
      //   */
      //
      //  .md body {
      //    --ion-background-color: #121212;
      //    --ion-background-color-rgb: 18,18,18;
      //
      //    --ion-text-color: #ffffff;
      //    --ion-text-color-rgb: 255,255,255;
      //
      //    --ion-border-color: #222222;
      //
      //    --ion-color-step-50: #1e1e1e;
      //    --ion-color-step-100: #2a2a2a;
      //    --ion-color-step-150: #363636;
      //    --ion-color-step-200: #414141;
      //    --ion-color-step-250: #4d4d4d;
      //    --ion-color-step-300: #595959;
      //    --ion-color-step-350: #656565;
      //    --ion-color-step-400: #717171;
      //    --ion-color-step-450: #7d7d7d;
      //    --ion-color-step-500: #898989;
      //    --ion-color-step-550: #949494;
      //    --ion-color-step-600: #a0a0a0;
      //    --ion-color-step-650: #acacac;
      //    --ion-color-step-700: #b8b8b8;
      //    --ion-color-step-750: #c4c4c4;
      //    --ion-color-step-800: #d0d0d0;
      //    --ion-color-step-850: #dbdbdb;
      //    --ion-color-step-900: #e7e7e7;
      //    --ion-color-step-950: #f3f3f3;
      //
      //    --ion-item-background: #1A1B1E;
      //  }
      //
      //  ion-title.title-large {
      //    --color: white;
      //  }
      //}
      

      希望能帮到你

      【讨论】:

        【解决方案6】:

        一种方法是通过使用媒体查询来强制使用灯光样式。在喜欢浅色的设备上,您可以提供深色主题变量,但您需要使用浅色主题变量覆盖 @media (prefers-color-scheme: dark) 范围。

        一种方法是为您的主题使用 mixin,并将其包含在 :root 范围和 @media (prefers-color-scheme: dark) 中。

        相反,如果您想强制使用深色主题,请为您的主题使用 mixin,并将其包含在 :root 范围和 @media (prefers-color-scheme: light) 中。

        注意:离子 (ionic/cli@6.10.0) 和 SCSS

        
        /**
        * {@mixin} - Supplies dark theme variables to the included scope
        */
        @mixin eternal-darkness() {
           // Dark theme variables...
        }
        
        :root {
           @include eternal-darkness;
        }
        
        @media (prefers-color-scheme: light) {
           @include eternal-darkness;
        }
        

        【讨论】:

          【解决方案7】:

          在我的网络浏览器中,主题很轻。这正是我想要的。

          在 ios 模拟器中,它是黑暗的。为了让它变得轻松,我这样做了:

          In variables.css
          
          @media (prefers-color-scheme: lights) {
           ...
          }
          

          【讨论】:

            【解决方案8】:

            只需将此标签放在index.html 文件中

            <meta name="color-scheme" content="light dark" />

            它对我有用!谢谢

            【讨论】:

              猜你喜欢
              • 1970-01-01
              • 2017-10-08
              • 1970-01-01
              • 2018-11-05
              • 2014-04-30
              • 2022-08-12
              • 2018-05-05
              • 2015-10-04
              • 2017-11-16
              相关资源
              最近更新 更多