2

我使用 Angular Elements (6.0.3) 创建了一个 Web 组件。当我在另一个网站中使用 Web 组件时,该 Web 组件会覆盖父页面的样式,因为它也使用 Bootstrap。我知道有视图封装原则,但据我所知“Native”封装还没有完全支持。所以现在我使用默认的“仿真”。

我发现如果我:host ::ng-deep在我的样式前面添加,它们只会应用于 Web 组件本身,这很棒。但是,我在 angular.json 中加载的所有 css 和 scss 文件似乎也覆盖了父页面。有什么办法可以防止导入的样式文件出现这种行为?

我在 angular.json 中的样式导入:

"styles": [
  "node_modules/intl-tel-input/build/css/intlTelInput.css",
  "node_modules/bootstrap/dist/css/bootstrap.min.css",
  "node_modules/angular-calendar/css/angular-calendar.css",
  "src/styles.scss",
  "node_modules/font-awesome/css/font-awesome.min.css",
  "src/assets/css/wizard.css",
  "src/assets/css/calendar.css",
  "src/assets/css/ng2-select.css"
]
4

1 回答 1

1

angular.json 中的“样式”导入用于您希望全局定义到整个应用程序的样式。要使用ViewEncapsulation,您需要将它们的样式表链接到它们的组件内部,如下所示:

@Component({
    selector: 'app-home',
    templateUrl: './home.component.html',
    styleUrls: ['./home.component.css'],
})
于 2018-06-29T15:57:02.030 回答