React-JSX에서 클래스와 스타일의 동적 바인딩을 구현하는 방법(예제 포함)
이 기사의 내용은 React-JSX에서 클래스와 스타일의 동적 바인딩을 구현하는 방법에 대한 것입니다. 이는 특정 참조 가치가 있으므로 도움이 될 것입니다.
요약: 요소의 클래스 목록과 인라인 스타일을 조작하는 것은 데이터 바인딩의 일반적인 요구 사항입니다. dom 요소를 자주 조작하면 JavaScript 성능이 저하됩니다. 고성능 js를 달성하려면 클래스와 스타일의 동적 바인딩이 필수입니다. 우수한 자격을 갖춘 프로그래머를 선택합니다. 이 글은 React-JSX 구문을 기반으로 하고 다른 프레임워크의 구현 방법과 결합하여 ClassName과 Style의 동적 바인딩을 구현하는 방법을 소개합니다.
참고: 이 기사의 예제는 검증되었습니다. 오류가 있으면 비판하고 수정하세요.
Bind HTML Class
Object 구문
className에 객체를 전달하여 클래스를 동적으로 전환할 수 있습니다.
참고: vue 및 작은 프로그램과 같은 개체 구문은 지원되지 않습니다.
오류 예:
render(){ return <p className={ 'box-color':this.state.isError }>hello world</p> }
구현할 수 있는 구문은 다음과 같습니다.
1 논리 연산자를 사용하세요
css 파일
.box-color { color:red; }
js 파일
render(){ return <p className={ this.state.isError && 'box-color' }>hello world</p> }
2. 세 개의 메타 연산자를 사용하세요
css 파일
.box-show { display: block; } .box-hide { display: none; }
render(){ return <p className={ this.state.isShow ? 'box-show' : 'box-hide' }>hello world</p> }
3. 함수를 사용하여 바인딩된 데이터 객체
는 템플릿에서 인라인으로 정의할 필요가 없습니다. vue
에서 계산된 후크 함수와 유사한 함수를 정의할 수 있습니다. js 파일
getIsError() { return this.state.isError ? 'box-color' : ''; } render(){ return <p className={ this.getIsError() }>hello world</p> }
참고: 다음과 같은 개체 변수 작성 방법은 지원되지 않으며 오류가 보고되지 않습니다. 콘솔 클래스 이름은 유효하지 않은 [object object]로 표시됩니다.
const classObj = { 'box-show': this.state.isShow, 'box-color': this.state.isError } render(){ return <p className={ classObj }>hello world</p> }
일반적으로 함수 바인딩 방법은 프로젝트 로직이 상대적으로 복잡한 시나리오에서 사용됩니다. 너무 많이 사용하면 뷰 레이어와 로직 레이어가 혼동되어 읽기 및 유지 관리가 어려워지는 것을 권장합니다. 클래스 정의를 동적으로 바인딩하는 연산자 및 삼항 연산자 메서드입니다.
Array 구문
React-JSX 구문은 className 배열 구문을 지원하지 않습니다. 다음 예를 시도해 보세요.
css file
.box-hide { display: none; } .box-color { color:red; }
js file
this.state = {isShow: false} render(){ return <p className={ this.state.isShow ? 'box-color' : [ 'box-color', 'box-hide'] }>hello world</p> }
Console 표시 결과(잘못됨, 중간에 추가 쉼표가 있음):
<p class="box-color, box-hide">hello world</p>
참고: 배열 구문을 지원하지 않기 때문에 "box-color"의 스타일을 "box-hide"로 재사용하고 삼항 연산자를 사용하여 표현하면 CSS 코드의 양이 늘어납니다.
바인드 인라인 스타일
객체 구문
스타일 객체 구문은 clasName 객체보다 더 직관적이며, 처리 기능이 더 간단합니다. 논리 연산자 메서드와 함수 바인딩 메서드는 className 구현을 참조할 수 있습니다. 아래 사용법:
삼항 연산자
Vue의 vue-if 및 WeChat 애플릿의 wx-if 명령과 유사하며 스타일 삼항 연산자
js 파일
render(){ return <p style={ this.state.isShow ? {display: 'inline-block'} : { display: 'none'} }>hello world</p> }
Array 구문
React-JSX를 사용하여 동적으로 구현할 수 있습니다. 스타일 배열 구문을 지원하지 않습니다. 예를 들어보세요.
js 파일
render(){ return <p style={ this.state.isShow ? {color: 'red'} : [{color: 'red'}, {display: 'inline-block'}] }></p> }
콘솔 표시 결과(잘못됨):
<p></p>
간단히 말하면, 고품질로 프로젝트 요구 사항을 완료하고 점점 더 복잡해지는 비즈니스 시나리오에 대처하려면 많은 수의 DOM 요소를 조작하고 스타일 변수에 무작위로 이름을 지정한 다음 이를 클래스와 스타일에 바인딩하는 것은 권장되지 않습니다.
추천 관련 기사:
링크 태그 링크 CSS와 @import 로딩의 차이점은 무엇인가요?
위 내용은 React-JSX에서 클래스와 스타일의 동적 바인딩을 구현하는 방법(예제 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











공식 계정 웹 페이지 업데이트 캐시, 이것은 간단하고 간단하며 냄비를 마시기에 충분히 복잡합니다. 공식 계정 기사를 업데이트하기 위해 열심히 노력했지만 사용자는 여전히 기존 버전을 열었습니까? 이 기사에서는이 뒤에있는 비틀기와 회전을 살펴 보고이 문제를 우아하게 해결하는 방법을 살펴 보겠습니다. 읽은 후에는 다양한 캐싱 문제를 쉽게 처리 할 수있어 사용자가 항상 가장 신선한 콘텐츠를 경험할 수 있습니다. 기본 사항에 대해 먼저 이야기 해 봅시다. 액세스 속도를 향상시키기 위해 브라우저 또는 서버는 일부 정적 리소스 (예 : 그림, CSS, JS) 또는 페이지 컨텐츠를 저장합니다. 다음에 액세스 할 때 다시 다운로드하지 않고도 캐시에서 직접 검색 할 수 있으며 자연스럽게 빠릅니다. 그러나 이것은 또한 양날의 검입니다. 새 버전은 온라인입니다.

이 기사는 CSS를 사용한 웹 페이지에 효율적인 PNG 테두리 추가를 보여줍니다. CSS는 JavaScript 또는 라이브러리에 비해 우수한 성능을 제공하며, 미묘하거나 눈에 띄는 효과를 위해 테두리 너비, 스타일 및 색상 조정 방법을 자세히 설명합니다.

이 기사에서는 브라우저에서 직접 사용자 입력을 검증하기 위해 필요한, Pattern, Min, Max 및 Length 한계와 같은 HTML5 양식 검증 속성을 사용하는 것에 대해 설명합니다.

기사는 HTML5 크로스 브라우저 호환성을 보장하기위한 모범 사례에 대해 논의하고 기능 감지, 점진적 향상 및 테스트 방법에 중점을 둡니다.

이 기사는 HTML & LT; Datalist & GT에 대해 논의합니다. 자동 완성 제안을 제공하고, 사용자 경험을 향상시키고, 오류를 줄임으로써 양식을 향상시키는 요소. 문자 수 : 159

이 기사는 HTML & lt; Progress & Gt에 대해 설명합니다. 요소, 그 목적, 스타일 및 & lt; meter & gt의 차이; 요소. 주요 초점은 & lt; progress & gt; 작업 완료 및 & lt; meter & gt; Stati의 경우

이 기사는 HTML & lt; meter & gt에 대해 설명합니다. 범위 내에 스칼라 또는 분수 값을 표시하는 데 사용되는 요소 및 웹 개발의 일반적인 응용 프로그램. & lt; meter & gt; & lt; Progress & Gt; 그리고 Ex

이 기사는 html5 & lt; time & gt; 시맨틱 날짜/시간 표현 요소. 인간이 읽을 수있는 텍스트와 함께 기계 가독성 (ISO 8601 형식)에 대한 DateTime 속성의 중요성을 강조하여 Accessibilit를 향상시킵니다.
