AngularJS-Anwendungen erfordern häufig separate Stylesheets für verschiedene Ansichten, um die Benutzererfahrung zu verbessern. Wenn Sie jedoch Elemente in einzelnen Ansichten können zu Leistungsproblemen führen. In diesem Artikel wird eine umfassende Lösung zum dynamischen Laden ansichtsspezifischer Stylesheets untersucht, wodurch Layoutverschiebungen minimiert werden.
Die vorgeschlagene Lösung umfasst die Erstellung einer benutzerdefinierten Direktive für den
Element und Aktualisieren der AngularJS $routeProvider-Konfiguration.Benutzerdefinierte Direktive:
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) { ... (code to add/remove `<link>` elements based on routes) ... }); } } }]);
AngularJS-Routenkonfiguration:
app.config(['$routeProvider', function($routeProvider){ $routeProvider .when('/some/route/1', { templateUrl: 'partials/partial1.html', controller: 'Partial1Ctrl', css: 'css/partial1.css' }) ... (other routes as needed) ... }]);
Das obige ist der detaillierte Inhalt vonWie verwaltet man ansichtsspezifische Stylesheets in AngularJS-Anwendungen effizient?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!