반응의 기능은 무엇입니까? 반응 기능의 상세 분석(예제 포함)
이 글에서는 주로 react 학습 방법에 대해 설명합니다. 이제 글의 주요 내용을 살펴보겠습니다.
React는 기본적으로 JavaScript 라이브러리입니다.
앞면과 뒷면을 분리하는 아이디어를 구현하여 페이지를 조립하는 작업의 일부를 브라우저에 전송합니다. JSP 파일과 달리 페이지 레이아웃과 데이터 작성은 서버가 완료된 후 브라우저로 전송됩니다. 그것.
이 작업에는 당연히 많은 이점이 있습니다. 첫째, React는 DOM 및 JavaScript를 모듈(구성 요소)로 캡슐화합니다. 뿐만 아니라 구성 요소는 테스트 및 문제 분리를 단순화할 수도 있습니다. 둘째, 데이터가 변경되면 React는 자동으로 사용자 인터페이스를 업데이트하고 업데이트가 필요한 부분만 업데이트할 수 있습니다.
핵심 기능 1: render
이 기능의 기능은 페이지를 조립하는 데 사용되는 레고 장난감의 빌딩 블록과 같은 모듈을 제공하는 것입니다.
간단한 예: (html 코드가 먼저 제공되고 JSX 코드가 나중에 제공됩니다. JSX는 JavaScript+XML을 의미합니다.)
<p id="container" class="firstContainer"> <p>replaced</p> </p>/*************************************************/ReactDOM.render( <p>Hello, world!</p>, document.getElementsByClassName('firstContainer')[0] );
firstContainer 클래스가 있는 p의 내용이 다음 코드로 대체된 것을 볼 수 있습니다. 렌더링에 작성됨: Hello World!
또한 document.getElementsByClassName('firstContainer')[0]을 임의의 기본 JavaScript로 대체하여 단일 항목을 얻을 수 있습니다(Node여야 하므로 document.getElementsByClassName과 같은 메서드를 사용하는 경우 [n ] ) **DOM 요소 메소드: document.getElementById 또는 document.getElementsByTagName 등이 모두 허용됩니다.
더 복잡한 예를 들어 여기에서 <p>Hello, world!</p>
를 확장할 수 있습니다.
<p id="container" class="firstContainer"> <p>replaced</p> </p>/*************************************************/var name = "Emily"; ReactDOM.render( <p> { (function(){ return <p>Hello, {name}!</p> })() } </p>, document.getElementById('container') );
JSX 구문의 마법을 코드에서 보면 JS와 DOM이 혼합되어 있다고 할 수 있습니다. JSX의 기본 구문 규칙: HTML 태그(<로 시작)를 발견하면 HTML 규칙을 사용하여 코드 블록({로 시작)을 발견하면 JavaScript 규칙을 사용하여 구문 분석합니다.
핵심 함수 2: React.createClass
이 함수를 사용하면 필요한 구성 요소를 직접 정의할 수 있습니다. 정의된 구성 요소는 p와 같은 태그로 렌더링 함수에서 직접 사용할 수 있습니다.
간단한 밤:
<p id="container" class="firstContainer"> <p>replaced</p> </p>/*************************************************/var HelloWorldBox = React.createClass({ render: function() { return ( <p className="helloWorldBox"> Hello, world! I am a helloWorldBox. </p> ); } }); ReactDOM.render( <HelloWorldBox />, document.getElementById('container') );
이 밤에서는 HelloWorldBox가 가장 간단한 구성 요소입니다.
이 구성 요소에 대한 자세한 정보도 얻을 수 있습니다. 예를 들어 props 사용
(React 공식 웹사이트의 예)
<p id="container" class="firstContainer"> <p>replaced</p> </p>/*************************************************/var Comment = React.createClass({ render: function() { return ( <p className="comment"> <h2 className="commentAuthor"> {this.props.author} </h2> {this.props.children} </p> ); } });var CommentList = React.createClass({ render: function() { return ( <p className="commentList"> <Comment author="Pete Hunt">This is one comment</Comment> <Comment author="Jordan Walke">This is *another* comment</Comment> </p> ); } }); ReactDOM.render( <CommentList />, document.getElementById('container') );
이 밤나무에서는 React.createClass 메서드를 사용하여 두 개의 구성 요소를 생성합니다. CommentList 구성 요소에서 Comment가 중첩되어 있음을 의미합니다. , CommentList는 여러 개의 Comment로 구성됩니다. CommentList에서 Comment에 대한 속성을 정의합니다: 작성자. 그러면 Comment 컴포넌트에서는 {this.props.author}를 통해 이 속성을 읽을 수 있고, {this.props.children}을 통해 이 컴포넌트의 하위 노드를 읽을 수 있습니다.
외부 데이터 액세스:
<p id="container" class="firstContainer"> <p>replaced</p> </p>/*************************************************/var Comment = React.createClass({ render: function() { return ( <p className="comment"> <h2 className="commentAuthor"> {this.props.author} </h2> {this.props.children} </p> ); } });var names = ['Alice', 'Emily', 'Kate']; ReactDOM.render( <p> { names.map(function (name) { return <Comment author={name}>is an author~</Comment> }) } </p>, document.getElementById('container') );
여기서 배열 이름은 외부 데이터입니다. 구성 요소를 생성하여 이러한 데이터를 웹 페이지의 DOM에 삽입합니다.
Component state
각 구성 요소에는 상태 속성이 있습니다. 개발자는 this.setState()를 호출하여 구성 요소의 상태를 변경할 수 있습니다. 상태가 업데이트되면 구성 요소가 자체적으로 다시 렌더링됩니다. 상태와 소품 모두 컴포넌트의 특징이지만, 차이점은 소품은 변하지 않지만 상태는 바뀔 수 있다는 것입니다.
getInitialState()는 구성 요소의 초기화 상태를 설정할 수 있습니다. 이 함수는 구성 요소의 수명 주기에서 한 번만 실행됩니다.
업데이트 상태:
참고: componentDidMount 함수는 컴포넌트가 렌더링될 때 React가 자동으로 호출하는 메서드입니다.
var CommentBox = React.createClass({ getInitialState: function() { return {data: []}; }, componentDidMount: function() { $.ajax({ url: this.props.url, dataType: 'json', success: function(data) { this.setState({data: data}); }.bind(this), error: function(xhr, status, err) { console.error(this.props.url, status, err.toString()); }.bind(this) }); }, render: function() { return ( <p className="commentBox"> <h1>Comments</h1> <CommentList data={this.state.data} /> </p> ); } });
이 밤에는 ajax를 통해 데이터를 얻고, 얻은 데이터를 this.setState 함수를 통해 this.state.data로 설정합니다. 그런 다음 CommentList에서 data={this.state.data}를 설정하여 서버에서 가져온 데이터를 표시합니다. (자세한 내용을 알고 싶으면 PHP 중국어 웹사이트React 참조 매뉴얼 열을 참조하세요.)
컴포넌트의 수명주기
컴포넌트의 수명주기는 다음 세 가지 유형으로 나뉩니다.
마운팅: 실제 DOM이 삽입되었습니다
-
업데이트 중: 다시 렌더링 중
언마운트: 실제 DOM에서 이동되었습니다.
컴포넌트의 라이프 사이클에서 라이프 사이클 함수가 자동으로 호출됩니다.
componentWillMount()componentDidMount()componentWillUpdate(object nextProps, object nextState)componentDidUpdate(object prevProps, object prevState)componentWillUnmount()
두 가지 특수 상태 처리 함수도 있습니다.
componentWillReceiveProps(object nextProps):已加载组件收到新的参数时调用shouldComponentUpdate(object nextProps, object nextState):组件判断是否重新渲染时调用
다음 예는 Ruan Yifeng의 블로그에서 가져온 것입니다.
var Hello = React.createClass({ getInitialState: function () { return { opacity: 1.0 }; }, componentDidMount: function () { this.timer = setInterval(function () { var opacity = this.state.opacity; opacity -= .05; if (opacity < 0.1) { opacity = 1.0; } this.setState({ opacity: opacity }); }.bind(this), 100); }, render: function () { return ( <p style={{opacity: this.state.opacity}}> Hello {this.props.name} </p> ); } }); ReactDOM.render( <Hello name="world"/>, document.body );
commentDidMount 함수는 구성 요소가 실제 DOM에 삽입된 후에 호출됩니다. 구성 요소가 완전히 투명해질 때까지 100밀리초마다 투명도를 변경하도록 타이머를 설정한 다음 투명도를 1로 설정합니다(초기 투명도는 1로 설정됨). 이러한 방식으로 이 구성 요소 파티는 지속적으로 렌더링됩니다. 이런 방식으로 페이지에 깜박이는 Hello World 문자열이 표시됩니다.
componentDidUpdate:function(){ console.log("did update"); }
함수를 작성하면 콘솔에서 연속 출력을 볼 수 있습니다.
React는 기본적으로 JavaScript 라이브러리입니다.
앞면과 뒷면을 분리한다는 개념을 구현하고, 페이지를 조립하는 작업의 일부를 JSP 파일과 달리 브라우저로 전송하고, 페이지의 레이아웃과 데이터를 채우는 작업을 브라우저로 보냅니다. 서버가 완료한 후의 브라우저입니다.
이렇게 하면 당연히 많은 이점이 있습니다. 우선 React는 DOM과 JavaScript를 모듈(컴포넌트)로 캡슐화합니다. 뿐만 아니라 컴포넌트는 테스트와 주의를 분리할 수도 있습니다. 간단해야합니다. 둘째, 데이터가 변경되면 React는 자동으로 사용자 인터페이스를 업데이트하고 업데이트가 필요한 부분만 업데이트할 수 있습니다.
이 글은 여기에서 끝납니다. (자세한 내용을 보려면 PHP 중국어 웹사이트 React 사용자 매뉴얼 열을 방문하세요.) 아래에 메시지를 남겨주세요.
위 내용은 반응의 기능은 무엇입니까? 반응 기능의 상세 분석(예제 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











PHP, Vue 및 React: 가장 적합한 프런트엔드 프레임워크를 선택하는 방법은 무엇입니까? 인터넷 기술이 지속적으로 발전함에 따라 프런트엔드 프레임워크는 웹 개발에서 중요한 역할을 합니다. PHP, Vue, React는 세 가지 대표적인 프론트엔드 프레임워크로 각각 고유한 특성과 장점을 가지고 있습니다. 사용할 프런트 엔드 프레임워크를 선택할 때 개발자는 프로젝트 요구 사항, 팀 기술 및 개인 선호도를 기반으로 정보를 바탕으로 결정을 내려야 합니다. 이 글에서는 세 가지 프론트엔드 프레임워크인 PHP, Vue, React의 특징과 용도를 비교해보겠습니다.

Java 프레임워크와 React 프레임워크의 통합: 단계: 백엔드 Java 프레임워크를 설정합니다. 프로젝트 구조를 만듭니다. 빌드 도구를 구성합니다. React 애플리케이션을 만듭니다. REST API 엔드포인트를 작성합니다. 통신 메커니즘을 구성합니다. 실제 사례(SpringBoot+React): Java 코드: RESTfulAPI 컨트롤러를 정의합니다. React 코드: API에서 반환된 데이터를 가져오고 표시합니다.

JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법, 특정 코드 예제가 필요합니다. 서문: 웹 개발에서는 서버와의 데이터 상호 작용이 종종 포함됩니다. 서버와 통신할 때 반환된 HTTP 상태 코드를 가져와서 작업의 성공 여부를 확인하고 다양한 상태 코드에 따라 해당 처리를 수행해야 하는 경우가 많습니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법과 몇 가지 실용적인 코드 예제를 제공합니다. XMLHttpRequest 사용

JavaScript에서 HTTP 상태 코드를 얻는 방법 소개: 프런트 엔드 개발에서 우리는 종종 백엔드 인터페이스와의 상호 작용을 처리해야 하며 HTTP 상태 코드는 매우 중요한 부분입니다. HTTP 상태 코드를 이해하고 얻는 것은 인터페이스에서 반환된 데이터를 더 잘 처리하는 데 도움이 됩니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. HTTP 상태 코드란 무엇입니까? HTTP 상태 코드는 브라우저가 서버에 요청을 시작할 때 서비스가

vue.js는 중소형 프로젝트 및 빠른 반복에 적합한 반면 React는 크고 복잡한 응용 프로그램에 적합합니다. 1) vue.js는 사용하기 쉽고 팀이 불충분하거나 프로젝트 규모가 작는 상황에 적합합니다. 2) React는 더 풍부한 생태계를 가지고 있으며 고성능 및 복잡한 기능적 요구가있는 프로젝트에 적합합니다.

JavaScript 및 WebSocket: 효율적인 실시간 검색 엔진 구축 소개: 인터넷이 발전함에 따라 사용자는 실시간 검색 엔진에 대한 요구 사항이 점점 더 높아지고 있습니다. 기존 검색 엔진으로 검색할 때 사용자는 검색 버튼을 클릭해야 결과를 얻을 수 있습니다. 이 방법은 실시간 검색 결과에 대한 사용자의 요구를 충족할 수 없습니다. 따라서 JavaScript와 WebSocket 기술을 활용하여 실시간 검색 엔진을 구현하는 것이 화두가 되었습니다. 이 기사에서는 JavaScript의 사용법을 자세히 소개합니다.

React는 JSX와 HTML을 결합하여 사용자 경험을 향상시킵니다. 1) JSX는 개발을보다 직관적으로 만들기 위해 HTML을 포함시킨다. 2) 가상 DOM 메커니즘은 성능을 최적화하고 DOM 운영을 줄입니다. 3) 유지 보수성을 향상시키기위한 구성 요소 기반 관리 UI. 4) 상태 관리 및 이벤트 처리는 상호 작용을 향상시킵니다.

WebSocket 및 JavaScript를 사용하여 온라인 전자 서명 시스템을 구현하는 방법 개요: 디지털 시대의 도래와 함께 전자 서명은 다양한 산업에서 기존 종이 서명을 대체하는 데 널리 사용됩니다. WebSocket은 전이중 통신 프로토콜로서 서버와 실시간 양방향 데이터 전송을 수행할 수 있으며 JavaScript와 결합되어 온라인 전자 서명 시스템을 구현할 수 있습니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 간단한 온라인 개발을 수행하는 방법을 소개합니다.
