Separate Stylesheets in AngularJS-Ansichten
Die effiziente Verwaltung ansichtsspezifischer Stylesheets in AngularJS kann die Leistung verbessern und die Codeorganisation aufrechterhalten.
Inline-Stile in Ansichten: Das Beste noch einmal Praktiken
Vom Einfügen von Style-Tags direkt in HTML-Ansichten wird aufgrund möglicher Leistungsprobleme und Code-Unordnung abgeraten. Alternative Ansätze streben danach, die Auswirkungen auf das Seitenrendering zu minimieren.
Dynamisches CSS-Laden mit $routeProvider
In AngularJS bietet $routeProvider keine direkte Unterstützung für dynamisches CSS-Laden . Allerdings können benutzerdefinierte Lösungen implementiert werden, um diese Funktionalität zu erreichen.
CSS-Laden auf Abruf mit einer benutzerdefinierten Direktive
Ein Ansatz besteht darin, eine benutzerdefinierte Direktive zu erstellen, die Routenänderungen abfängt mit der Methode $rootScope.$on(). Diese Anweisung fügt Elemente im
Abschnitt basierend auf der für jede Route angegebenen CSS-Eigenschaft.app.directive('head', ['$rootScope','$compile', function($rootScope, $compile){ return { restrict: 'E', link: function(scope, elem){ var html = '<link rel="stylesheet" ng-repeat="(routeCtrl, cssUrl) in routeStyles" ng-href="{{cssUrl}}" />'; elem.append($compile(html)(scope)); scope.routeStyles = {}; $rootScope.$on('$routeChangeStart', function (e, next, current) { // Update CSS styles for route change // ... }); } }; } ]);
CSS-Eigenschaften für Routen festlegen
Innerhalb der $routeProvider-Konfiguration kann die CSS-Eigenschaft verwendet werden Definieren Sie ansichtsspezifische CSS-Dateien für jede Route.
app.config(['$routeProvider', function($routeProvider){ $routeProvider .when('/some/route/1', { templateUrl: 'partials/partial1.html', controller: 'Partial1Ctrl', css: 'css/partial1.css' }) .when('/some/route/2', { templateUrl: 'partials/partial2.html', controller: 'Partial2Ctrl', css: ['css/partial2_1.css','css/partial2_2.css'] }); }]);
Zusätzlich Überlegungen
Das obige ist der detaillierte Inhalt vonWie verwaltet man ansichtsspezifische Stylesheets in AngularJS effizient?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!