Blazor 컴포넌트 렌더링 오류: "Found malformed component comment"

  • 2 minutes to read

Blazor 애플리케이션을 작업할 때 다음과 같은 오류를 만날 수 있습니다:

blazor.server.js:1 Uncaught Error: Found malformed component comment at Blazor:{...}

이 오류는 Blazor 프레임워크가 서버 측 렌더링에 사용되는 컴포넌트 주석을 파싱하는 동안 문제가 발생했음을 나타냅니다. 원인은 종종 Razor 파일 내의 잘못된 HTML 구문 또는 컴포넌트 매개 변수와 관련이 있습니다.

일반적인 원인

  1. 닫히지 않은 HTML 태그: 이 오류의 가장 일반적인 원인은 Razor 파일 내에 닫히지 않았거나 잘못 닫힌 HTML 태그입니다.
  2. 잘못된 컴포넌트 매개 변수: Blazor 컴포넌트에 잘못 전달되었거나 누락된 매개 변수로 인해 발생할 수 있습니다.

예시 시나리오

다음과 같은 간단한 Razor 페이지에서 이 오류가 발생할 수 있습니다:

@page "/example"
@using Microsoft.AspNetCore.Components

<h3>Example Component</h3>

<p>This is an example paragraph.<p> <!-- 닫히지 않은 p 태그 -->

<component type="typeof(MyApp.Components.MyComponent)"
           render-mode="ServerPrerendered"
           param-MyParam="value" />

위 예시에서 <p> 태그를 잘못 사용한 것이 문제의 원인이었습니다. 닫는 태그가 <p>가 아니라 </p>여야 합니다.

해결 방법

문제를 해결하려면 HTML 태그를 올바르게 닫아야 합니다. 다음과 같이 수정할 수 있습니다:

@page "/example"
@using Microsoft.AspNetCore.Components

<h3>Example Component</h3>

<p>This is an example paragraph.</p> <!-- 올바르게 닫힌 p 태그 -->

<component type="typeof(MyApp.Components.MyComponent)"
           render-mode="ServerPrerendered"
           param-MyParam="value" />

결론

이 오류를 피하려면 HTML 태그를 올바르게 닫고, 모든 컴포넌트 매개 변수가 정확하게 전달되었는지 확인하십시오. 이러한 작은 실수가 종종 큰 문제를 일으킬 수 있으므로 주의 깊게 코드를 검토하는 것이 중요합니다.

더 깊이 공부하고 싶다면
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