inflearn logo
강의

Course

Instructor

Vue3 Perfect Master: From Basics to Practice - "Basic Edition"

Understanding Components

component 등록과 사용

58

logipick

4 asked

0

4분 53초쯤 app.component('BookComponent', BookComponent) 라고 등록을 하신건데 사용할 때는 왜 book-component 로 선언하시는건지 이해가 되지 않습니다.

vue.js

Answer 2

0

gymcoding

안녕하세요! 🙂

핵심은 어디에서 사용하느냐에 따라 달라집니다.

강의처럼 HTML 파일에서 직접 사용하는 경우(DOM 템플릿)에는 kebab-case(book-component)를 반드시 사용해야 해요. HTML 파서가 대소문자를 구분하지 않기 때문에 <BookComponent>라고 쓰면 브라우저가 <bookcomponent>로 바꿔버려서 Vue가 인식하지 못하거든요.

반면 .vue 파일의 <template> 안에서는 PascalCase(<BookComponent />), kebab-case(<book-component />) 둘 다 사용 가능합니다.

정리하면 이렇게 돼요.

  • HTML 파일에서 직접 사용<book-component> (kebab-case 필수)

  • .vue 파일 <template><BookComponent /> 또는 <book-component> 둘 다 가능

참고: https://vuejs.org/guide/components/registration.html#component-name-casing

0

communityai8509

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

Vue.js에서 컴포넌트를 사용할 때, app.component('BookComponent', BookComponent)처럼 컴포넌트를 등록할 때 사용하는 이름과 HTML 태그로 사용할 때의 이름이 다른 것은 Vue.js의 컴포넌트 명명 규칙 때문입니다.

Vue.js에서는 컴포넌트를 HTML에서 사용할 때, 대시(-)를 사용하여 kebab-case로 변환합니다. 예를 들어, BookComponent라는 PascalCase로 등록된 컴포넌트는 HTML에서 <book-component>와 같이 사용할 수 있습니다. 이는 HTML 템플릿에서 대소문자를 구별하지 않는 특성과의 호환성을 높이기 위함입니다.

관련하여 자세한 설명은 아래 링크를 참고해 주세요:
- 컴포넌트 네이밍 규칙에 대한 간단한 설명

이해가 안 되시거나 관련해서 더 궁금하신 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 추가로 답변해 주실 것입니다.

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

npm init vue@3.1.9

0

41

2

크롭 웹스토어 vue devtools 설치 관련

0

42

1

snippets 작성하는 부분 설명이 있었나요?

0

49

2

computed 의 set 함수를 통해 const 변수에 값을 담는 부분

0

53

2

소스 공유 어디서 해야하는지 궁금합니다

0

61

2

강의교안

0

56

2

eslint 룰 관련 질문이 있습니다.

0

64

2

npm init -y 명령어 실행에 관한 질문

0

154

2

volar 가 마켓플레이스에 검색되지 않아 vue(official)을 설치했습니다.

0

168

2

깊은 감시자 질문

0

88

2

정리된 내용

0

155

2

화면이 왜 이렇게 뜨는걸까요?

0

186

2

왜 다르게 뜰까요..?ㅠㅠ

0

155

2

npm init vue , npm create vue@latest 명령 오류

0

294

2

강의를 듣다보니 궁금한 점 질문드립니다.

0

141

2

watch강의 질문

0

153

1

강의 듣다가 질문드립니다.

0

119

1

이벤트 처리 부분 강의 실습

0

141

2

v-pre는 설명이 없나요?

0

153

2

AppCard.vue 만들다 말고 오류가 갑자기 엄청 뜹니다

0

146

1

개발자도구 Vue 탭 관련 문의

0

240

2

강의를 인텔리제이로 수업따라가도 되져?

0

178

2

API 사용시 자동으로 import하는 기능은 어떤것을 설치해야 하나요?

3

279

2

이벤트 수식어 event 전달인자 관련 질문

0

138

1