AngularJS 튜토리얼 #16 - 뷰와 라우트
테이블 목차
- 뷰와 라우팅에 대한 개요
- 싱글 페이지 애플리케이션 소개
- 다양한 뷰 구성
- 뷰 파일 생성하기
- 라우팅 설정하기
- 의존성 주입
- config 메소드 작성
- 라우트 설정
- 기본 경로 설정
- 라우팅 활용하기
- 클린 URL 사용하기
📂 뷰와 라우팅에 대한 개요
웹 애플리케이션을 개발할 때, 다양한 뷰를 활용하는 것은 중요합니다. 앵귤러JS에서 뷰와 라우팅을 효과적으로 다루는 방법을 알아보겠습니다. 먼저 싱글 페이지 애플리케이션의 개념에 대해 알아보고, 다양한 뷰를 구성하는 방법에 대해서도 살펴보겠습니다.
싱글 페이지 애플리케이션 소개
앵귤러JS는 대부분의 싱글 페이지 애플리케이션(SPA)에서 사용됩니다. SPA는 페이지를 전환할 때 새로운 페이지를 요청하는 대신, 필요한 뷰만 요청하여 동적으로 변경하는 방식입니다. 이렇게 하면 페이지 간의 전환 속도를 빠르게 만들 수 있고, 사용자 경험을 향상시킬 수 있습니다.
다양한 뷰 구성
기존에는 닌자 목록만을 보여주는 뷰를 사용했습니다. 하지만 애플리케이션이 복잡해지면, 홈 뷰, 연락처 뷰, 소개 뷰 등 다양한 뷰가 필요해집니다. 이제 이러한 뷰들을 별도의 파일로 만들어 보겠습니다.
뷰 파일 생성하기
먼저 뷰 파일을 생성하기 위해 뷰 폴더를 만들어야 합니다. 프로젝트의 루트 디렉토리에 views
라는 이름의 폴더를 생성합니다. 이 폴더에 각각의 뷰 파일을 저장할 것입니다.
뷰 폴더 생성
views
폴더를 생성한 후, 각 뷰에 대한 파일을 만들 것입니다. 뷰 폴더 안에 directory.html
과 home.html
이라는 파일을 생성합니다.
뷰 파일 작성
directory.html
파일에는 닌자 목록 뷰의 내용을 작성합니다. home.html
파일은 홈 뷰의 내용을 작성하는데, 일단 제목만 입력하고 추후에 내용을 추가할 예정입니다.
🛠️ 라우팅 설정하기
이제 생성한 뷰 파일들을 어떻게 연결할지 설정해야 합니다. 라우팅을 설정하여 사용자가 링크를 클릭할 때 이에 맞는 뷰를 요청하고, 그 결과를 알맞은 위치에 삽입할 것입니다.
의존성 주입
라우팅을 구현하기 위해서는 ngRoute
모듈에 대한 의존성 주입이 필요합니다. 우리는 이미 angular-route.min.js
파일을 다운로드했으므로 이를 연결하고 의존성으로 주입해야 합니다.
config 메소드 작성
config 메소드를 사용하여 라우팅 설정을 작성합니다. 이 메소드는 애플리케이션 실행 전에 라우팅과 관련된 코드를 실행하는 역할을 합니다. 의존성 주입을 통해 routeProvider
객체를 전달받을 것이므로 이를 매개변수로 받아와야 합니다.
라우트 설정
$routeProvider
객체를 사용하여 여러 개의 라우트를 설정할 수 있습니다. 각각의 라우트는 URL 패턴과 해당 URL에 맞는 뷰 파일을 연결해야 합니다.
기본 경로 설정
$routeProvider
객체의 otherwise
메소드를 사용하여 모든 다른 URL에 대한 처리 방법을 설정할 수 있습니다. 일반적으로 이 설정을 사용하여 기본 경로를 설정합니다. 기본 경로는 사용자가 라우트에 지정된 URL 이외의 URL을 입력했을 경우 보여줄 초기 뷰를 설정하는 것입니다.
🖇️ 라우팅 활용하기
이제 설정한 라우팅을 통해 링크 클릭에 따라 뷰가 변경되는 기능을 활용해봅시다. 링크를 클릭하면 해당하는 뷰가 보여지도록 설정할 것입니다.
링크 설정
헤더에 있는 링크를 설정하여 사용자가 클릭할 수 있도록 만듭니다. home
링크에는 #home
URL을, list ninjas
링크에는 #directory
URL을 설정합니다.
링크 클릭 시 뷰 변경
링크를 클릭하면 해당하는 URL로 이동하고, 앵귤러JS가 설정한 뷰 파일을 가져와서 적절한 위치에 삽입합니다. 이를 위해 ng-view
디렉티브를 사용하여 뷰를 삽입할 위치를 지정합니다.
🔗 클린 URL 사용하기
링크의 URL에 해시 기호(#)를 제거하여 보다 깔끔한 URL을 사용할 수 있습니다. 이를 위해 조금 더 설정을 추가해야 합니다. 해시 기호를 제거하는 방법에 대해 다음에 자세히 알아보겠습니다.
위의 내용을 통해 앵귤러JS를 활용한 뷰와 라우팅의 기본적인 사용법에 대해 배웠습니다. 이제 웹 애플리케이션 개발에 따라 사용자 경험을 개선하는 다양한 기능들을 추가할 수 있을 것입니다. 질문이 있으시면 언제든지 댓글로 남겨주세요!
하이라이트
- 앵귤러JS를 활용한 뷰와 라우팅 개요
- 싱글 페이지 애플리케이션의 개념과 장점
- 다양한 뷰를 생성하고 뷰 파일 구성 방법
- 라우팅 설정 및 기본 경로 설정 방법
- 링크 클릭 시 뷰 변경 기능 구현 방법
- 클린 URL 사용하여 보다 깔끔한 URL 표시 방법
자주 묻는 질문
Q: 싱글 페이지 애플리케이션은 어떤 장점이 있나요?
A: 싱글 페이지 애플리케이션은 페이지 간 전환 시 속도가 빠르고 사용자 경험이 좋아집니다. 또한 서버의 부담도 줄어들며, 편리한 개발과 유지보수가 가능합니다.
Q: 뷰 파일을 어떻게 생성하고 관리해야 하나요?
A: 뷰 파일은 보통 별도의 폴더에 저장하여 관리합니다. 각각의 파일은 해당하는 뷰에 대한 HTML 코드를 포함하고 있으며, 필요에 따라 CSS와 JavaScript 코드도 포함할 수 있습니다.
Q: 기본 경로 설정이 필요한 이유는 무엇인가요?
A: 기본 경로 설정은 사용자가 지정한 URL 이외의 URL을 입력했을 때 보여줄 초기 뷰를 설정하기 위해 사용됩니다. 기본 경로를 설정하지 않으면 애플리케이션에서 정의되지 않은 URL로 접근 시 404 오류가 발생할 수 있습니다.
참고 자료