Angular2 动态更改 CSS 属性

IT技术 javascript angular dart angular-dart
2021-03-05 18:18:40

我们正在制作一个Angular2 应用程序,我们希望能够以某种方式创建一个全局 CSS 变量(并在分配变量时更新属性值)。

我们已经使用 Polymer 一段时间了(现在我们正在切换到 Angular2 组件)并且我们使用了 CSS 属性(Polymer 有一些 polyfill)并且我们刚刚使用Polymer.updateStyles().

有什么办法可以实现类似的功能吗?

编辑:

我们想要一些类似于 Sasscolor: $g-main-color或 CSS 自定义属性的东西,color: var(--g-main-color)并且每当我们决定更改属性的值时,例如像updateVariable('g-main-color', '#112a4f')这样的东西动态地更新无处不在的值。所有这一切都在应用程序运行时。

编辑2:

我想在我的 CSS 的不同部分(主机、子元素...)使用一些全局 CSS 变量,并且能够立即更改该值 - 所以如果我更改 my-color 变量,它会在 app.js 中的任何地方更改。

例如,我将使用 Sass 语法:

:host { border: 2px solid $my-color }
:host .some-label { color: $my-color }

是否可以使用 Angular 管道之类的东西?(但据说它只适用于 HTML)

:host { border: 2px solid {{ 'my-color' | cssvariable }} }
:host .some-label { color: {{ 'my-color' | cssvariable }} }
5个回答

1) 使用内联样式

<div [style.color]="myDynamicColor">

2) 使用多个 CSS 类映射到您想要的内容并切换类,例如:

 /* CSS */
 .theme { /* any shared styles */ }
 .theme.blue { color: blue; }
 .theme.red { color: red; }

 /* Template */
 <div class="theme" [ngClass]="{blue: isBlue, red: isRed}">
 <div class="theme" [class.blue]="isBlue">

代码示例来自:https : //angular.io/cheatsheet

有关 ngClass 指令的更多信息:https ://angular.io/docs/ts/latest/api/common/index/NgClass-directive.html

这可能有效,但有一个问题 - 您必须将动态样式与 CSS 文件分开,这绝不是最好的方法。:( 我宁愿在 CSS 中加入一些东西,但我可能不得不处理它。
2021-04-21 18:18:40
我确实说过有像 Angular2 管道这样的东西会很好 - 能够将它写在 CSS 文件或区域中。但这可能是不可能的,所以我必须像你在 1) 中写的那样做,也许只是在 Sass 文件中添加注释,从外部使用(或应该使用)全局变量。
2021-05-08 18:18:40
如果你喜欢冒险,你可以构建一个步骤来使用 SASS 并输出一个你可以导入的 JS module ^_^
2021-05-08 18:18:40
我不明白。使用 SASS/LESS。对于来自 JavaScript 的动态样式,我只能看到那些。无论如何,除非您做错了,否则您不能混合静态和动态样式。静态:css。动态:JavaScript。
2021-05-15 18:18:40
对包含数字的变量没有用,你不想创建 10000 个类
2021-05-15 18:18:40

只需使用标准 CSS 变量:

您的全局 css(例如:styles.css)

body {
  --my-var: #000
}

在您组件的 css 或其他任何内容中:

span {
  color: var(--my-var)
}

然后你可以直接用 TS/JS 通过将内联样式设置为 html 元素来更改变量的值:

document.querySelector("body").style.cssText = "--my-var: #000";

否则,您可以使用 jQuery:

$("body").css("--my-var", "#fff");
看看这个,来自 Angular 文档的 Renderer2:angular.io/api/core/Renderer2
2021-04-24 18:18:40
这正是我想要的,谢谢分享
2021-04-28 18:18:40
@GiantElk 是的,但我只是在更改 CSS 变量值。由于不支持在 ngStyle 中绑定 CSS 变量,我认为这实际上是最简单的解决方案。就我个人而言,我永远不会使用像 Renderer 这样困难的 API 来改变变量的值。
2021-05-15 18:18:40
使用 Angular 2.0+ 时,使用直接 DOM 操作和 jQuery 不是最后的手段吗?
2021-05-16 18:18:40

您没有任何示例代码,但我假设您想做这样的事情?

@View({
directives: [NgClass],
styles: [`
    .${TodoModel.COMPLETED}  {
        text-decoration: line-through;
    }
    .${TodoModel.STARTED} {
        color: green;
    }
`],
template: `<div>
                <span [ng-class]="todo.status" >{{todo.title}}</span>
                <button (click)="todo.toggle()" >Toggle status</button>
            </div>`
})

您分配ng-class给一个动态变量(TodoModel您可以猜测的模型属性)。

todo.toggle()正在改变 的值,todo.status并且输入的类正在改变。

这是一个类名的例子,但实际上你可以对 css 属性做同样的思考。

我希望这就是你的意思。

此示例适用于此处的精彩蛋头教程

那不是我们想要的。我们想要像 Sasscolor: $g-main-color或 CSS 自定义属性那样的东西color: var(--g-main-color),每当我们决定改变属性的值时,例如像 JSupdateVariable('g-main-color', '#112a4f')这样的东西,它会在任何地方动态更新值。所有这一切都在应用程序运行时。
2021-05-12 18:18:40

我做了这个 plunker来探索一种方法来做你想做的事。

在这里,我mystyle从父组件获取,但您可以从服务获取它。

import {Component, View} from 'angular2/angular2'

@Component({
  selector: '[my-person]',
  inputs: [
    'name',
    'mystyle: customstyle'
  ],
  host: {
    '[style.backgroundColor]': 'mystyle.backgroundColor'
  }
})
@View({
  template: `My Person Component: {{ name }}`
})
export class Person {}
我必须能够更改宿主元素和子元素的样式,而您的解决方案无法更改这些样式,而且在“CSS 区域”之外编写样式有点凌乱。看看编辑 2。顺便说一句。与其通过属性从输入中获取颜色,不如只导入一些类并从中使用一个变量,因为我想要整个应用程序的全局变量。;)
2021-05-07 18:18:40

Angular 6 + Alyle 用户界面

使用 Alyle UI,您可以动态更改样式

这是一个演示 stackblitz

@NgModule({
  declarations: [
    AppComponent
  ],
  imports: [
    BrowserModule,
    CommonModule,
    FormsModule,
    HttpClientModule,
    BrowserAnimationsModule,
    AlyleUIModule.forRoot(
      {
        name: 'myTheme',
        primary: {
          default: '#00bcd4'
        },
        accent: {
          default: '#ff4081'
        },
        scheme: 'myCustomScheme', // myCustomScheme from colorSchemes
        lightGreen: '#8bc34a',
        colorSchemes: {
          light: {
            myColor: 'teal',
          },
          dark: {
            myColor: '#FF923D'
          },
          myCustomScheme: {
            background: {
              primary: '#dde4e6',
            },
            text: {
              default: '#fff'
            },
            myColor: '#C362FF'
          }
        }
      }
    ),
    LyCommonModule, // for bg, color, raised and others
  ],
  bootstrap: [AppComponent]
})
export class AppModule { }

html

<div [className]="classes.card">dynamic style</div>
<p color="myColor">myColor</p>
<p bg="myColor">myColor</p>

改变风格

import { Component } from '@angular/core';
import { LyTheme } from '@alyle/ui';

@Component({ ... })
export class AppComponent  {
  classes = {
    card: this.theme.setStyle(
      'card', // key
      () => (
        // style
        `background-color: ${this.theme.palette.myColor};` +
        `position: relative;` +
        `margin: 1em;` +
        `text-align: center;`
         ...
      )
    )
  }
  constructor(
    public theme: LyTheme
  ) { }

  changeScheme() {
    const scheme = this.theme.palette.scheme === 'light' ?
    'dark' : this.theme.palette.scheme === 'dark' ?
    'myCustomScheme' : 'light';
    this.theme.setScheme(scheme);
  }
}

Github 存储库

问题是关于 Dart。我想这行不通。
2021-05-16 18:18:40