스택큐힙리스트

파싱 오류: 인접한 JSX 요소는 둘러싸는 태그로 감싸져야 합니다. 본문

카테고리 없음

파싱 오류: 인접한 JSX 요소는 둘러싸는 태그로 감싸져야 합니다.

스택큐힙리스트 2023. 12. 25. 07:48
반응형

React.js 앱을 설정하려고 하고 있습니다. 변수가 true로 설정되었을 때만 렌더링되도록하려고합니다.


내 렌더링 함수가 다음과 같이 설정되어 있습니다:


render: function() {
var text = this.state.submitted ? '고맙습니다! '+email+'에서 곧 후속 조치를 기대하십시오!' : '얼른 액세스 요청용 이메일을 입력하십시오:';
var style = this.state.submitted ? {backgroundColor: rgba(26, 188, 156, 0.4)} : {};
return (
<div>
if(this.state.submitted==false)
{
<input type=email className=input_field onChange={this._updateInputValue} ref=email value={this.state.email} />
<ReactCSSTransitionGroup transitionName=example transitionAppear={true}>
<div className=button-row>
<a href=# className=button onClick={this.saveAndContinue}>초대 요청</a>
</div>
</ReactCSSTransitionGroup>
}
</div>
)
},

기본적으로 여기서 중요한 부분은 if(this.state.submitted==false) 부분입니다 (이 div 요소들은 submitted 변수가 false로 설정되었을 때 나타나도록 원합니다).


하지만 이를 실행하면 문제점이 발생합니다:



Uncaught Error: Parse Error: Line 38: 인접한 JSX 요소는 둘러싸는 태그로 감싸져야 합니다



여기서 문제가 무엇인가요? 그리고 이를 해결하기 위해 어떤 것을 사용할 수 있을까요?

답변 1

구성 요소를 둘러싸는 태그 사이에 배치해야 합니다. 즉:


// 잘못된 형식!
return (
<Comp1 />
<Comp2 />
)

대신:


// 올바른 형식
return (
<div>
<Comp1 />
<Comp2 />
</div>
)

편집: Joe Clay의 Fragments API에 대한 설명을 참고하세요.


// 더 올바른 형식
return (
<React.Fragment>
<Comp1 />
<Comp2 />
</React.Fragment>
)
// 간략한 구문
return (
<>
<Comp1 />
<Comp2 />
</>
)

답변 2

제목: 인접한 JSX 요소는 둘러싸는 태그로 감싸야 하는 문제에 대한 SEO-conscious 한 에세이
서문:
JSX(JavaScript XML)는 React와 같은 프론트엔드 프레임워크에서 사용되는 자바스크립트의 확장 문법입니다. JSX는 UI 컴포넌트를 작성하기 위해 JavaScript와 XML의 혼합된 형태로 작성됩니다. 그러나 JSX에서 혼동이 있을 수 있는 부분 중 하나는 인접한 JSX 요소는 둘러싸는 태그로 감싸야 한다는 규칙입니다. 이 규칙이 왜 필요한지에 대해 SEO-conscious한 관점에서 다뤄보겠습니다.
본론:
1. 검색 엔진 최적화(SEO)의 중요성:
오늘날 인터넷 검색은 사용자들이 정보를 얻는 주요한 방법 중 하나입니다. 따라서 웹 페이지의 검색 엔진 최적화(SEO)는 웹사이트의 노출성과 트래픽을 증가시키는 데 중요한 역할을 합니다. SEO는 사용자 경험, 콘텐츠의 품질, 웹 사이트의 구조 등 다양한 요소에 의해 영향을 받습니다. 이에 따라 JSX에서 인접한 요소 감싸기 규칙도 SEO에 영향을 미칠 수 있습니다.
2. 웹 크롤러 동작 원리:
웹 크롤러는 검색 엔진이 웹 페이지를 검색하고 색인화하는 데 사용하는 프로그램입니다. 웹 크롤러는 HTML을 읽어 구조화하고 특정 요소와 콘텐츠를 식별합니다. 이때, 웹 크롤러는 HTML 구조에 따라 페이지를 이해하고 분석합니다. JSX에서 인접한 요소가 둘러싸여 있지 않을 경우 웹 크롤러는 원래 의도된 구조를 파악하지 못하고 정보를 올바르게 인식할 수 없습니다.
3. 검색 엔진 색인화의 어려움:
인접한 JSX 요소를 둘러싸지 않으면 검색 엔진은 페이지 구조에 대한 정보를 식별하기 어렵습니다. 검색 엔진은 웹 페이지를 색인화할 때 페이지의 구조와 계층 구조를 이용해서 콘텐츠와 연결시키기 때문입니다. 만약 인접한 JSX 요소가 감싸지지 않으면 일부 콘텐츠의 계층 구조가 손실되거나 잘못된 계층 구조가 형성될 수 있습니다. 이는 검색 엔진이 적절한 키워드와 연결되지 않은 콘텐츠를 인식할 수 없게 되어 검색 결과에 노출되기 어렵게 만듭니다.
4. 검색 가능성 개선을 위한 제안:
인접한 JSX 요소를 둘러싸는 방법으로는 여러 가지가 있습니다. 가장 일반적인 방법은 div 요소를 사용하여 JSX 요소를 둘러싸는 것입니다. 이를 통해 검색 엔진은 적절한 구조를 파악하고 페이지를 잘 인덱싱할 수 있습니다. 또한 semantic한 HTML 태그를 사용하여 컨텐츠에 의미를 부여함으로써 검색 가능성을 향상시킬 수도 있습니다. 예를 들어, 'header', 'main', 'footer'와 같은 태그를 사용하여 페이지의 주요 영역을 명확하게 구분할 수 있습니다.
결론:
JSX의 인접한 요소 감싸기는 검색 엔진 최적화와 관련하여 중요한 사항입니다. SEO-conscious 한 웹 개발자들은 이 규칙을 준수하여 웹 페이지를 구성하고, 적절한 구조와 계층 구조를 제공함으로써 검색 엔진에서 노출되는 가능성을 향상시킬 수 있습니다. 인접한 JSX 요소는 더 나은 검색 결과와 사용자 경험을 제공하기 위해 적절히 태그로 감싸야 합니다.

반응형
Comments