Heim >Web-Frontend >CSS-Tutorial >Wie kann ich die CSS-Eigenschaften untergeordneter Komponenten in Angular 4 mit ::ng-deep überschreiben?

Wie kann ich die CSS-Eigenschaften untergeordneter Komponenten in Angular 4 mit ::ng-deep überschreiben?

DDD
DDDOriginal
2024-10-29 21:47:021080Durchsuche

How can I override child component CSS properties in Angular 4 using ::ng-deep?

Überschreiben von CSS-Eigenschaften untergeordneter Komponenten mit ::ng-deep in Angular 4

In Angular 4 ermöglicht der Selektor ::ng-deep dies Sie können CSS-Eigenschaften untergeordneter Komponenten im CSS der übergeordneten Komponente überschreiben. Dies wird erreicht, indem die Schatten-DOM-Grenze der untergeordneten Komponenten durchbrochen wird.

Verwendung:

Um ::ng-deep zu verwenden, stellen Sie es einfach dem CSS-Selektor voran das auf das Element der untergeordneten Komponente abzielt, etwa so:

<code class="css">::ng-deep .child-component {
  /* CSS properties to override */
}</code>

Beispiel:

Bedenken Sie die folgende HTML-Struktur:

<code class="html"><parent-component>
  <child-component class="child"></child-component>
</parent-component></code>

Zu überschreiben Um die Stile der p-Elemente innerhalb der untergeordneten Komponente zu ändern, können Sie das folgende CSS in der übergeordneten Komponente verwenden:

<code class="css">::ng-deep .child p {
  color: red;
}</code>

IE11-Unterstützung:

::ng -deep wird in Internet Explorer 11 nicht unterstützt. Wenn Sie IE11 unterstützen müssen, sollten Sie stattdessen den alternativen Selektor :host-context() verwenden. Allerdings hat :host-context() seine eigenen Einschränkungen und ist möglicherweise nicht für alle Fälle geeignet.

Das obige ist der detaillierte Inhalt vonWie kann ich die CSS-Eigenschaften untergeordneter Komponenten in Angular 4 mit ::ng-deep überschreiben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn