inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

Vue 3 & Firebase 10 커뮤니티 만들기 풀스택 - "활용편" (with Pinia, Quasar, Tiptap, VueUse)

웹 레이아웃 구성 : router-link vs router.push

route.meta? 에서 물음표 개념

116

김주원

작성한 질문수 39

0

안녕하세요~

웹 레이아웃 구성 default.vue 파일의 코드 일부분 입니다.

route.meta? 에서 ?물음표개념이 어떻게 될까요?
지워도 작동해서 질문 드립니다.

답변 주시면 감사하겠습니다.

 

const pageContainerStyles = computed(() => ({
  maxWidth: route.meta?.width || '1080px',
  margin: '0 auto',
}));

 

 

vue.js firebase quasar algolia vue-3

답변 2

1

짐코딩

해당 ?. 문법은 자바스크립트의 옵셔널 체이닝(Optional Chaining) 연산자입니다. 객체의 중첩된 속성을 안전하게 접근할 수 있게 해주죠.

// route.meta가 없어도 에러가 발생하지 않고 undefined 반환
route.meta?.width 

// route.meta가 없으면 에러 발생!
route.meta.width

route.meta가 없을 때 에러를 방지하기 위한 안전장치라고 생각하시면 됩니다. 현재는 meta가 항상 존재해서 ?를 제거해도 작동하지만, 향후 meta가 없는 경우를 대비한 방어적 코딩 방식입니다.

0

김주원

답변 감사 드립니다~

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 김주원님.

질문하신 route.meta?.width에서 사용된 ?는 JavaScript에서 “Optional Chaining”이라는 기능을 나타내는 것입니다. 이 문법은 객체의 속성이 존재하지 않는 경우에도 오류를 발생시키지 않고 undefined를 반환하는 방법입니다.

즉, route.metaundefined일 경우 .width에 접근하려고 하면 보통 오류가 발생하지만, meta?를 사용하면 undefined를 반환하고 코드가 정상적으로 이어질 수 있도록 합니다. 따라서 route.meta가 정의되지 않았더라도 나머지 코드가 에러 없이 실행됩니다.

예를 들어, route.meta가 존재하지 않거나 구조상 빈 객체라면, route.meta?.widthundefined로 평가되고, 이 경우 maxWidth'1080px'로 설정되게 됩니다.

Optional Chaining은 코드가 더 안정적으로 오류 없이 실행되도록 도와주기 때문에 매우 유용한 기능입니다. route.meta에서 ?를 제거해도 현재 상황에서는 작동할 수 있지만, meta가 없는 상황을 대비해 안전하게 코드를 작성하려면 ?를 사용하는 것이 좋습니다.

관련 내용은 공식 문서나 다음 리소스를 참조하면 유용합니다:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

storage 사용 문의

0

71

2

무한 스크롤링 질문

0

77

2

짐코딩님..! unplugin-vue-router/vite 적용 최근방식 부탁드령요 ㅜㅜ

0

146

3

Quasar를 강의 버전 그대로 맞추면 실행할 때 에러가 발생해서, 다른 버전만 맞추니 잘 작동합니다.

1

93

1

post/[id]/index.vue에서 layouts/default.vue가 안 나오는 데 어떤 이유일까요?

0

136

2

Cross-Origin-Opener-Policy policy would block the window.closed call.

0

422

2

[공유] 잘동작하는 unplugin-vue-router 버전 관련

0

262

2

functions.region is not a function

1

219

1

unplugin-vue-router 가 안되네요.

0

266

2

건의사항

0

177

1

Firebase Hosting 후 페이지 안뜰 때!

0

179

1

type : negative 무슨 의미인가요?

0

191

2

강의 교안은 어떻게 볼 수 있나요?

0

260

2

플로그인 설치

0

230

2

Firebase 요금제에 관한 문의사항

0

278

1

사용자 컴포넌트를 작성하는 것에 대한 문의

0

173

1

Firebase 강의 Section1의 Auto page 설정에 관련되어

0

342

2

tiptap 스타일 파일은 따로 안 올려주시나요?

0

352

1

LocalStorage 값 변경 자동 체크

0

530

1

Volar Deprecated

0

667

1

호스팅 문제 관련 질문 있습니다.

0

218

1

안녕하세요!

0

280

1

emit, prop 대신 defineModel()을 사용하여 구현 하는 것에 대한 질문 입니다.

0

660

1

안녕하세요! tiptap 강의 듣는중인데

0

343

1