我正在尝试将引导仪表板模板集成到Angular8项目中。但是我在resource not found
中链接css文件时遇到index.html
错误,
<link rel="stylesheet" href="./src/assets/css/theme.min.css" id="stylesheetLight">
<link rel="stylesheet" href="./src/assets/css/theme-dark.min.css" id="stylesheetDark">
在我的模板中,他们在每个样式表中使用了id属性。由于这个id属性(id="stylesheetLight"
),我无法将其导入; style.css
和angular.json
都没有。而且,如果不指定ID,则会破坏设计。
如何解决资源未找到错误?还是有什么方法可以将style.css
中的ID指定为@import
?
答案 0 :(得分:2)
您必须将其添加到 angular.json 文件中:
"options": {
...
"styles": [
"src/styles.css",
"src/assets/css/theme.min.css"
"src/assets/css/theme-dark.min.css"
],
"scripts": [],
"assets": [
...
]
}
在Angular中,添加像<link rel="stylesheet" href="./src/assets/css/theme.min.css" id="stylesheetLight">
这样的样式表不是正确的方法
答案 1 :(得分:0)
您可以创建样式表,例如“ shared.css”,并将其添加到angular.json
文件中:
"styles": [
"node_modules/bootstrap/dist/css/bootstrap.min.css",
"src/shared.css"
],
,并有条件地使用您的样式:
[class.my-class]="foo=='light'"
答案 2 :(得分:0)
我有同样的问题,我要添加id的原因是因为我想从https://material.angular.io/guide/theming
<link id="themeAsset" rel="stylesheet" href="/path/to/my/theme-name.css">
function changeTheme(themeName) {
document.getElementById('themeAsset').href = `/path/to/my/${themeName}.css`;
}
所以我可以通过单击更改整个应用程序样式的样式,而不是将类添加到每个组件中