웹 프론트엔드 CSS 튜토리얼 AngularJS에서 뷰별 스타일시트를 동적으로 관리하는 방법은 무엇입니까?

AngularJS에서 뷰별 스타일시트를 동적으로 관리하는 방법은 무엇입니까?

Dec 02, 2024 pm 10:35 PM

How to Dynamically Manage View-Specific Stylesheets in AngularJS?

AngularJS에 뷰별 스타일을 포함하는 방법

다양한 뷰에 대한 스타일시트를 적절하게 관리하는 것은 AngularJS 애플리케이션에서 필수적입니다. 전통적으로 이는 각 보기의 HTML 내에 요소를 직접 추가합니다. 그러나 이 접근 방식은 성능 문제와 유지 관리 문제로 이어질 수 있으므로 브라우저 지원에도 불구하고 좋지 않은 관행으로 간주됩니다.

선호되는 접근 방식

선호되는 방법은 동적으로 로드하는 것입니다. 특정 보기로 이동하는 경우에만 스타일시트가 표시됩니다. 이렇게 하면 최적의 성능이 보장되고 스타일이 지정되지 않은 콘텐츠가 깜박이는 것을 방지할 수 있습니다. 이를 달성하는 방법은 다음과 같습니다.

1. 에 대한 사용자 지정 지시문을 만듭니다. 요소

이 지시문은 페이지별 요소를 섹션.

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) {
        if(current && current.$$route && current.$$route.css){
          if(!angular.isArray(current.$$route.css)){
            current.$$route.css = [current.$$route.css];
          }
          angular.forEach(current.$$route.css, function(sheet){
            delete scope.routeStyles[sheet];
          });
        }
        if(next && next.$$route && next.$$route.css){
          if(!angular.isArray(next.$$route.css)){
            next.$$route.css = [next.$$route.css];
          }
          angular.forEach(next.$$route.css, function(sheet){
            scope.routeStyles[sheet] = sheet;
          });
        }
      });
    }
  };
}]);
로그인 후 복사

2. $routeProvider

에서 스타일시트 연관 지정 여기에는 각 경로 구성 객체에 CSS 속성을 추가하는 작업이 포함됩니다. 값은 스타일시트 경로를 나타내는 단일 문자열이거나 여러 스타일시트에 대한 문자열 배열일 수 있습니다.

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'
    })
    .when('/some/route/3', {
      templateUrl: 'partials/partial3.html',
      controller: 'Partial3Ctrl',
      css: ['css/partial3_1.css','css/partial3_2.css']
    })
}]);
로그인 후 복사

이 설정은 지정된 스타일시트를 해당 뷰를 탐색할 때만 요소를 사용하여 최적의 성능과 일관된 사용자 경험을 보장합니다.

위 내용은 AngularJS에서 뷰별 스타일시트를 동적으로 관리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Smart Forms 프레임 워크로 JavaScript 연락처 양식 작성 Smart Forms 프레임 워크로 JavaScript 연락처 양식 작성 Mar 07, 2025 am 11:33 AM

Smart Forms 프레임 워크로 JavaScript 연락처 양식 작성

WordPress 블록 및 요소에 상자 그림자를 추가합니다 WordPress 블록 및 요소에 상자 그림자를 추가합니다 Mar 09, 2025 pm 12:53 PM

WordPress 블록 및 요소에 상자 그림자를 추가합니다

스크린 독자를 탈취시킵니다. 액세스 가능한 양식 및 모범 사례 스크린 독자를 탈취시킵니다. 액세스 가능한 양식 및 모범 사례 Mar 08, 2025 am 09:45 AM

스크린 독자를 탈취시킵니다. 액세스 가능한 양식 및 모범 사례

내용 부호 ​​속성으로 인라인 텍스트 편집기를 만듭니다 내용 부호 ​​속성으로 인라인 텍스트 편집기를 만듭니다 Mar 02, 2025 am 09:03 AM

내용 부호 ​​속성으로 인라인 텍스트 편집기를 만듭니다

GraphQL 캐싱 작업 GraphQL 캐싱 작업 Mar 19, 2025 am 09:36 AM

GraphQL 캐싱 작업

첫 번째 맞춤형 전환을 만듭니다 첫 번째 맞춤형 전환을 만듭니다 Mar 15, 2025 am 11:08 AM

첫 번째 맞춤형 전환을 만듭니다

node.js 및 Express의 Multer와 함께 파일 업로드 node.js 및 Express의 Multer와 함께 파일 업로드 Mar 02, 2025 am 09:15 AM

node.js 및 Express의 Multer와 함께 파일 업로드

5 개의 최고의 PHP 양식 빌더 (및 3 개의 무료 스크립트) 비교 5 개의 최고의 PHP 양식 빌더 (및 3 개의 무료 스크립트) 비교 Mar 04, 2025 am 10:22 AM

5 개의 최고의 PHP 양식 빌더 (및 3 개의 무료 스크립트) 비교

See all articles