노트: Blazor는 아직 기술 지원이 제공되지 않는 실험용 웹 프레임워크로, 실무 개발에 사용되어서는 안됩니다.
Blazor는 단일 페이지 웹 앱 (SPA) 프레임워크로 브라우저 안에서 웹 어셈블리로 실행되며, .NET으로 만들어졌습니다.
.NET 은 무료로 제공되며, 크로스 플랫폼이면서, 서로 다른 수많은 종류의 앱 (데스크탑, 모바일, 게임, 웹)을 만들기 위한 오픈 소스 개발자 플랫폼입니다. .NET에는 관리되는 런타임, 표준화된 라이브러리가 포함되어있으며, 그리고 여러 모던 프로그래밍 언어들: C#, F#, 그리고 VB를 지원합니다. 10분 안에 .NET 시작하기 가이드를 참고하여 .NET을 배울 수 있습니다.
브라우저 안에서 .NET을 사용하면 웹 개발을 보다 쉽고 생산적으로 만들기 위한 많은 장점을 누릴 수 있습니다:
- 안정성과 일관성: .NET은 표준 API, 도구, 그리고 빌드 인프라를 모든 .NET 플랫폼에 걸쳐 안정적이고, 풍부한 기능을 제공하면서도, 사용하기 쉽게 제공합니다.
- 혁신적인 모던 언어: .NET의 여러 언어들 중 C# 과 F#은 여러 새롭고 혁신적인 언어 기능들을 통하여 프로그래밍을 더 재미있고 더 향상시킬 수 있게 도와줍니다.
- 업계를 선도하는 도구: Visual Studio 제품군은 최고의 .NET 개발 환경을 Windows, Linux, 그리고 macOS에서 제공합니다.
- 빠른 속도와 확장성: .NET은 성능, 안정성, 그리고 보안을 서버에서 제공하기 위한 긴 경험을 가지고 있습니다. .NET을 풀 스택 솔루션으로서 사용하면 여러분의 앱을 더 손쉽게 확장할 수 있습니다.
.NET을 브라우저에서 실행할 수 있는 것은 새로운 웹 표준 기술인 웹 어셈블리에 의하여 가능해 졌습니다. 웸 어셈블리는 "웹으로의 컴파일에 적합한 이식 가능한 크기 및 빠른 로딩 시간을 보장하는 형식"입니다. 웹 어셈블리로 컴파일된 코드는 어떤 브라우저에서든 네이티브와 같은 속도로 실행할 수 있습니다. .NET 바이너리를 웹 브라우저에서 실행하기 위해서는, 웹 어셈블리로 컴파일된 .NET 런타임 (구체적으로는 Mono)을 사용해야 합니다.
아니오, 하나의 Blazor 앱은 보통의 컴파일된 .NET 어셈블리로 웹 어셈블리 기반의 .NET 런타임을 사용하여 웹 브라우저에 의하여 다운로드되고 실행됩니다. .NET 런타임 그 자체만이 웹 어셈블리로서 컴파일됩니다. 나중에는 앱의 전체 코드를 정적 (AoT) 컴파일 기능을 사용하여 웹 어셈블리로 변환하는 것을 추가하게 될 수도 있습니다.
반드시 그렇지는 않습니다. .NET 런타임은 모든 형태의 크기로 제공됩니다. 초기의 Blazor 프로토타입은 경량화된 .NET 런타임 (어셈블리 실행, 가비지 컬렉션, 스레딩 기능을 제공하는) 을 사용하여 60KB 내외의 웹 어셈블리로 컴파일되도록 만들어졌습니다. 이제 Blazor는 이전보다 훨씬 크기가 큰 Mono 위에서 실행됩니다. 하지만, 그러나 런타임 및 응용 프로그램 바이너리의 병합 및 트리밍을 비롯하여, 아직 전송될 파일들의 크기에 관해서는 최적화할 여지가 많이 남았습니다. 그 외에도, 캐싱과 CDN을 사용하는 전략도 생각하고 있습니다.
Blazor는 모던 SPA 프레임워크라면 기대할 수 있는 다음의 기능들을 지원할 것입니다:
- 조합 가능한 UI를 만들기 위한 컴포넌트 모델
- 라우팅
- 레이아웃
- 폼과 유효성 검사
- 의존성 주입
- JavaScript 연동
- 개발 중에 동적 새로 고침 지원
- 서버 측 렌더링
- 브라우저와 IDE에서 모두 사용 가능한 완전한 .NET 디버깅 지원
- 개선된 IntelliSense 지원과 도구
- asm.js를 통한 오래된 (웹 어셈블리를 지원하지 않는) 브라우저에서의 실행 지원
- 게시 및 앱 크기 최적화
예. Blazor 앱은 정적 파일들로 배포되기 때문에 서버가 .NET을 지원하는지의 여부는 아무런 상관이 없습니다.
예! Blazor는 부수적으로 ASP.NET Core와의 연동을 통하여 자연스럽고 일관성있는 풀 스택 웹 개발 솔루션을 제공합니다.
Blazor는 기존의 모던 SPA 앱 프레임워크인 React, Angular, 그리고 Vue에서 영감을 얻어 만든 새로운 프레임워크 입니다.
첫 Blazor 웹 앱을 만들기 위해서는 Blazor 시작하기 문서를 참고하세요.
Blazor는 실험적 프로젝트입니다. 왜냐하면 쓰임새와 유용성에 대해서 풀어야 할 과제들이 많이 남았기 때문입니다. 이 실험용 프로젝트의 초기 목적은 다음과 같습니다.
- Work through technical issues.
- Gauge interest and to listen to feedback.
Blazor의 미래에 대해서는 낙관적으로 보고 있습니다. 그러나 지금 Blazor는 완전한 제품이 아니며, 극 초기 단계의 프로토타입으로서만 고려되어야 합니다.
아니오, Blazor는 HTML과 CSS를 기반으로 하는 .NET 웹 프레임워크로 공개된 웹 표준을 사용하여 브라우저 안에서 실행됩니다. 플러그인은 전혀 필요하지 않으며, 모바일 장치와 오래된 브라우저에서도 실행됩니다.
아니오, Blazor는 HTML, CSS, 그리고 다른 표준 웹 기술을 기반으로하는 웹 프레임워크입니다.
네, WebAssembly는 크로스 브라우저에서 실행되기 위해 필요한 합의를 달성했고, 모든 최신 웹 브라우저들이 실행을 지원합니다..
네, 최신 모바일 브라우저들도 WebAssembly를 지원합니다..
WebAssembly를 지원하지 않는 오래된 브라우저들에 대해서, Blazor는 더 느리고 더 많은 용량을 다운로드해야 하는 대신, 꽤 정상적인 기능을 보장하는 asm.js 기반의 .NET 런타임을 사용하도록 대처합니다.
네, Blazor를 위하여 사용되는 .NET 런타임은 .NET Standard 2.0을 지원합니다. 단, 브라우저 안에서 지원되지 않는 API들은 기능이 지원되지 않음을 알리는 예외 를 발생시킵니다.
아니오, WebAssembly의 현재 상태로도 충분합니다. .NET 런타임이 자체적으로 가비지 수집과 다중 스레드에 대한 것을 처리합니다.
예, Blazor 앱은 JavaScript를 JavaScript 상호 연동 API를 통하여 호출할 수 있습니다.
.NET 코드에서 JavaScript 연동을 통해 DOM에 접근할 수는 있습니다. 하지만, Blazor는 DOM에 직접 접근해야 할 필요성을 최소화하는 컴포넌트 기반 프레임워크입니다.
Mono는 Microsoft가 후원하는 .NET Framework의 오픈 소스 구현체입니다. Mono는 Xamarin 이 네이티브 클라이언트 앱을 Android, iOS, 그리고 macOS를 만들기 위하여 사용하고 있습니다. 또한 Mono는 Unity 가 게임 개발을 위하여 사용하고 있습니다. Microsoft의 Xamarin 팀은 Mono에 WebAssembly를 추가하기 위한 계획을 발표하였고, 꾸준히 진행하고 있습니다. (Mono와 WebAssembly - 정적 컴파일에 관한 소식 1/16/2018). Blazor는 WebAssembly에 대해 동작하는 클라이언트 측 웹 UI 프레임워크이기 때문에, Mono를 선택하는 것이 가장 적절합니다.
반면에, .NET Core는 주로 서버 앱과 크로스 플랫폼 콘솔 앱에 사용되는 것에 초점이 맞추어져 있습니다. .NET Core는 Blazor 앱을 위한 ASP.NET Core 백엔드를 만들 수 있지만, 클라이언트 앱 그 자체를 만드는 것은 아닙니다. CoreRT는 AoT 컴파일에 최적화된 .NET Core 런타임이며, WebAssembly에 대한 지원 계획도 가지고는 있지만, 아직 개발이 진행 중이며 완성된 제품이 아닙니다.
Blazor는 Razor라는 HTML과 C#을 위한 마크업 언어를 매우 많이 사용합니다. 즉, Browser + Razor = Blazor 입니다! 발음할 때에도, 패션, 스타일, 그리고 프로그래밍 언어에 대한 탁월한 감각을 지닌 힙스터들이 즐겨 입는 멋진 재킷의 이름과도 비슷합니다.