繁体   English   中英

(Angular) 如何禁用组件模板中的“链接”标签?

[英](Angular) How can I disable 'link' tag in component template?

为了用一个例子解释当前的情况,我在“index.html”中使用“link”标签导入了“1.css”以供全局使用,

  <link href="assets/css/1.css" rel="stylesheet" type="text/css" />

在a,b,c三个组件中,我不会使用"c"组件模板中的"1.css"。

那么如何禁用css呢?

$('link[href="assets/css/1.css"]').each(function() { this.remove(); });

你需要把它放在jquery onload fucntion里面

我是这样解决这个问题的。

ngOnInit(): void{
this.disableCSS("1.css", true);
}

...

  disableCSS(cssFileName: string){
    for (let i = 0; i<= document.styleSheets.length; i++ ){
      if( typeof document.styleSheets[i] !== 'undefined' ){
        if( typeof document.styleSheets[i].href !== "undefined" && document.styleSheets[i].href !== null){
          if( document.styleSheets[i].href.includes( cssFileName ) ){
            document.styleSheets[i].disabled = true;
          } 
        }
      }
    }
  }

并像 thie 一样重新禁用 CSS:

ngOnDestroy(){
this.disableCSS("board.css", false);
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM