ASP.NET Core 레이아웃 페이지에서 메뉴 클릭 시 active CSS 클래스 적용하기

  • 2 minutes to read

active CSS class 적용하기

ASP.NET Core 레이아웃 페이지에서 메뉴를 클릭했을 때 active CSS 클래스를 적용하는 방법은 다음과 같습니다. JavaScript 코드를 추가하여 현재 페이지의 URL과 일치하는 메뉴 항목에 active 클래스를 추가합니다.

먼저, site.css 파일 또는 _Layout.cshtml 파일에 다음과 같이 active 클래스 스타일을 정의해주세요.

.nav-item.active > .nav-link {
    background-color: #f8f9fa;
    color: #495057;
}

그런 다음, _Layout.cshtml 파일에 다음 JavaScript 코드를 추가합니다.

<script>
    // DOMContentLoaded 이벤트 리스너를 등록하여 문서 로드가 완료되면 실행
    document.addEventListener("DOMContentLoaded", function () {
        // 현재 페이지의 URL 경로를 가져옴
        var currentPageUrl = window.location.pathname;
        // 모든 .nav-item 요소를 선택
        var navItems = document.querySelectorAll(".nav-item");

        // navItems의 각 요소에 대해 반복
        navItems.forEach(function (navItem) {
            // .nav-link 요소를 찾음
            var navLink = navItem.querySelector(".nav-link");

            // navLink의 href 속성 값이 현재 페이지 URL과 일치하는지 확인
            if (navLink.getAttribute("href") === currentPageUrl) {
                // 일치한다면, 해당 navItem에 'active' 클래스를 추가
                navItem.classList.add("active");
            }
            else {
                // 일치하지 않는다면, 해당 navItem에서 'active' 클래스를 제거
                navItem.classList.remove("active");
            }
        });
    });
</script>

이렇게 하면 현재 페이지에 맞는 메뉴 항목에 active 클래스가 추가되어 해당 메뉴가 강조되어 표시됩니다.

더 깊이 공부하고 싶다면
DevLec에서는 실무 중심의 C#, .NET, ASP.NET Core, Blazor, 데이터 액세스 강좌를 단계별로 제공합니다. 현재 수강 가능한 강좌 외에도 더 많은 과정이 준비되어 있습니다.
DevLec.com에서 자세한 커리큘럼을 확인해 보세요.
DevLec 공식 강의
C# Programming
C# 프로그래밍 입문
프로그래밍을 처음 시작하는 입문자를 위한 C# 기본기 완성 과정입니다.
ASP.NET Core 10.0
ASP.NET Core 10.0 시작하기 MVC Fundamentals Part 1 MVC Fundamentals Part 2
웹 애플리케이션의 구조와 MVC 패턴을 ASP.NET Core로 실습하며 익힐 수 있습니다.
Blazor Server
풀스택 웹개발자 과정 Part 1 풀스택 웹개발자 과정 Part 2 풀스택 웹개발자 과정 Part 3
실무에서 바로 활용 가능한 Blazor Server 기반 관리자·포털 프로젝트를 만들어 봅니다.
Data & APIs
Entity Framework Core 시작하기 ADO.NET Fundamentals Blazor Server Fundamentals Minimal APIs
데이터 액세스와 Web API를 함께 이해하면 실무 .NET 백엔드 개발에 큰 도움이 됩니다.
VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com