ChatGPT解决这个技术问题 Extra ChatGPT

Angular2将类添加到body标签

如何在不将主体作为应用选择器并使用主机绑定的情况下将类添加到主体标记?

我尝试使用渲染器,但它改变了整个身体

Angular 2.x bind class on body tag

我正在开发一个大型 angular2 应用程序,更改根选择器会影响很多代码,我将不得不更改很多代码

我的用例是这样的:

当我打开一个模态组件(动态创建)时,我希望隐藏文档滚动条

实际上,如果您在 html 页面中使用 js,那么使用 document.body.className|classList 有什么问题?
哈哈,要是这么简单就好了 :) 但是直接访问 dom 是一种不好的做法
您可以编写一个大包装器,该包装器将在几秒钟内执行,最后将 class 添加到 body。如果您不打算使用服务器渲染或 Web Worker,您害怕什么?
所以没有比这更好的解决方案了吗?
我无法理解这些无缘无故投票和关闭问题的辱骂者

T
Tsvetan Ganev

我很想发表评论。但由于缺少声誉,我写了一个答案。好吧,我知道解决这个问题的两种可能性。

注入全局文档。好吧,这可能不是最佳实践,因为我不知道 nativescript 等是否支持它。但至少比使用纯 JS 好。

constructor(@Inject(DOCUMENT) private document: Document) {}

ngOnInit(){
   this.document.body.classList.add('test');
}

好吧,也许甚至更好。您可以注入渲染器或渲染器 2(在 NG4 上)并使用渲染器添加类。

export class myModalComponent implements OnDestroy {

  constructor(private renderer: Renderer) {
    this.renderer.setElementClass(document.body, 'modal-open', true);
  }

  ngOnDestroy(): void {
    this.renderer.setElementClass(document.body, 'modal-open', false);
  }
}

编辑 ANGULAR4:

import { Component, OnDestroy, Renderer2 } from '@angular/core';

export class myModalComponent implements OnDestroy {

  constructor(private renderer: Renderer2) {
    this.renderer.addClass(document.body, 'modal-open');
  }

  ngOnDestroy(): void {
    this.renderer.removeClass(document.body, 'modal-open');
  }
}

感谢您的回复,我认为使用渲染器是最好的解决方案
如果有人想知道从哪里获得 DOCUMENT,那就是:import { DOCUMENT } from '@angular/platform-browser'
渲染器解决方案要好得多。在 Angular 4 中,Renderer 已被弃用,取而代之的是 Renderer2。代码必须更改为:this.renderer.addClass(document.body, 'modal-open');this.renderer.removeClass(document.body, 'modal-open');
此外,构造函数中不再需要 @Inject(DOCUMENT)
作为@Neph 的更新:不推荐从平台浏览器导入文档。请改用@angular/common。
D
DHainzl

我认为最好的方法是上面 DaniS 的两种方法的组合:使用渲染器实际设置/删除类,但也使用文档注入器,因此它不强烈依赖于 window.document 但可以被动态替换(例如在渲染服务器端时)。所以整个代码看起来像这样:

import { DOCUMENT } from '@angular/common';
import { Component, Inject, OnDestroy, OnInit, Renderer2 } from '@angular/core';

@Component({ /* ... */ })
export class MyModalComponent implements OnInit, OnDestroy {
    constructor (
        @Inject(DOCUMENT) private document: Document,
        private renderer: Renderer2,
    ) { }

    ngOnInit(): void {
        this.renderer.addClass(this.document.body, 'embedded-body');
    }

    ngOnDestroy(): void {
        this.renderer.removeClass(this.document.body, 'embedded-body');
    }
}

这非常适合向 body 元素添加深色主题类!