I'm using Angular 2 with SystemJS and trying to add a stylesheet to a component.
Since I'm using SystemJS I can't use relative path as of now, so I used absolute path for the component's template url and also the style url.
However inline style works fine (i.e styles: ['h1 {font-size: 12px; }']
)
The component looks something like this:
@Component({
selector: 'dashboard',
templateUrl: '/app/components/dashboard/dashboard.html',
styleUrls: ['/app/components/dashboard/dashboard.css']
})
The stylesheet dashboard.css
never gets loaded(nor does it returns any error).
~ angular 2: 2.0.0-beta.6
~ systemjs: 0.19.20
~ typescript: 1.8.0
You just need to remove the slash from the beginning of the styleUrls path like this:
@Component({ selector: 'dashboard', templateUrl: '/app/components/dashboard/dashboard.html', styleUrls: ['app/components/dashboard/dashboard.css'] })
If you are using PrimeNG or Angular Material in your project that styleUrl will not work like this. You need to import ViewEncapsulation and put encapsulation: ViewEncapsulation.None in the @component definition.
import { Component, Output, Input, ViewEncapsulation} from '@angular/core'; @Component({ encapsulation: ViewEncapsulation.None, selector: 'message-center', templateUrl: './messagecenter.component.html', styleUrls: ['./messagecenter.component.css'] })
Angular 2 docs say that SystemJS exposes __moduleName variable required for relative names just like module.id for CommonJS... Have you tried that?
declare var __moduleName: any;
@Component({
moduleId: __moduleName,
selector: 'dashboard',
templateUrl: 'dashboard.html',
styleUrls: ['dashboard.css']
})
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With