기본 콘텐츠로 건너뛰기

react.js - tutorial (기본문법)




특징.
 - 페이지 갱신시에 필요한 부분만 갱신할 수 있다.
 - html을 이루는 element를 재사용할 수 있다.
 - jsx라는 문법 사용

angular.js 도 그렇고, 요즘 javascript들 보면
html의 <div> 와 같은 요소들을 OOP마냥 클래스로 찍어내서 만들어내는듯 하다.
덕분에 html페이지는 코드라인수도 줄어들고 간결해질것이고,
이를 보좌하는 *.js 들이 많이 생길것이다.
그와중에 react가 좀 더 매력적인건
DOM을 직접관리하여 렌더링 비용을 줄일 수 있다는 점이
react가 점차 대세가 되는 이유인듯 싶다.

그래서 facebook의 tutorail 을 한번 따라해봤다.
https://facebook.github.io/react/docs/tutorial.html
react tutorial에 나오는 <div> 하나짜리 간단한 예제다.

javascript 변수에 div태그를 사용하는 react class를 할당하고,
하단에 ReactDOM.render를 에서 그 변수를 렌더링한다.
그말인 즉슨,
div를 만들었지만 그걸 쓸지 말지 정하는곳은 다른곳이며,
그곳에서 페이지내에 모든 html 요소들을 관리할 수 도 있다라는 말이다.
웬지 관리가 조금 재밌어 질듯하다.

 *<script type="text/babel">
  ECMAScript6 문법을 사용하기 위함

위와 똑 같은 결과물을 보여주는 코드다.
다만 이번에는 jsx라는 문법을 사용하지 않은 방식이다.
'<','>' 같은 문자들이 없어져서 html 스러운 느낌이 많이 줄었지만
라인수가 적어서 그런지,
아직 둘중에 어떤게 더 쓰기 편한지 단정짓기 이른감이 있다.


<div> != <div>
react.js 영역내에서 사용하는 div는 DOM의 node가 아니라고 한다.
하는 역할은 유사하지만, 이것은 단지 react component일 뿐이다.
따라서, 기본적으로 react.js는 XSS 문제에서 안전하다.


component 구성
이번엔 위에서 만든 CommentBox내에 div를 몇개 추가해보자.


CommentList, CommentForm이라는 component를 생성하고
CommnetBox내에 CommentList,Form에 매핑될 div를 추가하였다.
ReactDom.render는 건들 필요 없다.


data전달을 위한 속성추가
component를 생성했으면, 이번엔 속성도 추가해보자.
이런 속성들은 data를 주고 받을때 종종 사용된다.

Commnet라는 component를 생성했고, CommentList 내부에 추가했다.
이 둘은 commnet내에 {this.props} 라는 문법을 통해 data를 주고 받을 수 있다.
이해를 돕기위해 렌더링된 html은 다음과 같다.
CommentList의 속성authro의 값을 Comment에서 받아서 <h2>로 처리된걸 확인할 수 있다. 마찬가지로 CommnetList에 children을 추가했다면 </h2>이후에 표시될것이다.
단 위의 경우는 </h2> 다음에 문장이 먼저 입력이 되어있기때문에 children은 표시되지 않는다. 하지만 'This is one comment' 라는 문장을 지우고 children을 추가하면 그때는 children이 표시된다.
<div class="commentList" is="null">
 <!-- react-text: 5 -->Hello, world! I am a CommentList.<!-- /react-text -->
  <div class="comment" is="null">
    <h2 class="commentAuthor" is="null">Pete Hunt</h2>
     <!-- react-text: 8 -->This is one comment<!-- /react-text -->   
  </div>
  <div class="comment" is="null">
    <h2 class="commentAuthor" is="null">Jordan Walke</h2>
    <!-- react-text: 11 -->This is *another* comment<!-- /react-text --></div>
 </div>
</div>



JSON (props)

json형태의 데이터를 전달하는 방법이다.
json형태의 변수 data를 생성하고 <CommentBox>하위에 <CommentList> 에 할당했다.
ReactDOM.render()에서 <CommentBox>다시 렌더링하기로 한다.



Reactive state

이전에 사용한 props는 immutable한 것이라고 한다. 부모가 자식에게 데이터를 전달할때는
props를 사용하고, component 내부에서 데이터를 수시로 변경할때는 state를 사용한다.




댓글

이 블로그의 인기 게시물

메일서버가 스팸으로 취급받을때

설치한 메일서버를 통해 발송되는 메일이 스팸으로 들어가는 경우가 더러 있다. 이게 한번 들어가기는 쉬운데, 빠져나오기는 드럽게 힘든것 같다... 본인의 경우에는 우선 국내서비스에는 별 무리 없이 들어간다. (naver,daum 등) 그런데 해외메일 그중 Gmail, Hotmail 에는 에누리없이 스팸으로 간주되고 있었다. Gmail같은 경우에는 그래도 스팸함으로 발송은 제대로 되는반면에 Hotmail같은경우에는 아예 수신자체가 안되는 경우도 더러있다.. ㅡ,.ㅡ; 제일 좋은 방법은 Gmail,Hotmail에 전화걸어서 우리 메일서버 IP white Ip로 등록해달라!!! 하면 좋지만, 얘네들은 걸어봤자 자동응답기고, 문의채널은 구글 그룹스 게시판이 전부다.. 본론으로 들어가서. 해외 메일이 차단될 경우 내 매일서버ip가 스팸ip로 등록되 버린 경우일 수 있다. (본인처럼. ㅎ) 이것부터 조회 해보고 싶으면 RBL(real-time blocking List) 체크를 해야 하는데, RBL체크 해주는 사이트는 꽤 많이 있고, 그중 좀 깔끔해 보이는곳 하나 소개. http://www.anti-abuse.org/ 메일서버ip 입력하고 조회해보면 쭈루룩 리스트가 나온다. 그 중 빨간불이 들어온 부분이 메일 서버가 스팸서버가 된 각종 이유들이다.ㅋ 본인의 경우 CBL 때문에 걸렸는데, 내용은 아래와 같다. This IP address is HELO'ing as  "localhost.localdomain"  which violates the relevant standards (specifically: RFC5321). 메일서버 도메인에 별다른 작업을 안해놓아서 "localhost.localdomain" 으로 설정되어있었다. 만약 CBL만 바로 테스트 해보고 싶으면 http://cbl.abusea

[javascript] 특정시간에만 함수 실행

특정시간에만 팝업을 띄우려면?? 특정시간에만 로그인을 막으려면?? 특정시간에만 할일은 의외로 참 많다. 방법? 딱히 없다. 현재시간 구해서 시작시간, 종료시간 사이에 있을때 시작하는 수밖엔. if ((현재시간 > 시작시간) && (현재시간 < 종료시간)){ .. 팝업노출(); 공사페이지 리다이렉트(); 기타등등(); .. } 자바스크립트로 작성하면 다음과 같다. var startdate = "2014012008" ; var enddate = "2014012418" ; var now = new Date (); //현재시간 year = now. getFullYear (); //현재시간 중 4자리 연도 month = now. getMonth () + 1 ; //현재시간 중 달. 달은 0부터 시작하기 때문에 +1 if ((month + "" ). length < 2 ){ month = "0" + month; //달의 숫자가 1자리면 앞에 0을 붙임. } date = now. getDate (); //현재 시간 중 날짜. if ((date + "" ). length < 2 ){ date = "0" + date; } hour = now. getHours (); //현재 시간 중 시간. if ((hour + "" ). length < 2 ){ hour = "0" + hour; } today = year + "" + month + "" + date + "" + hour; //오늘 날짜 완성. / / 시간비교 i

[linux] 모든 cron 확인

예전에 만들어놓은 cron이 요새 안돌고 있어서 찾아봤다. 물론 내가 만들었던 아니고ㅋ crontab -l no crontab for root 헐, 내가 찾던 cron이 안보인다. 분명히 예전 사수가 여기다 작업 해놓은것 같았는데... cron이 뭐하는 놈인지는 알아도, 어떻게 생겨먹은놈인지는 몰랐다ㅋ 이리저리 폴더 뒤져서 그때 스크립트 파일을 찾아보기 시작했다. 멍청한짓을 한 참 한후에 혹하는 마음에 로컬 사용자 뭐있나 찍어봄 cat /etc/passwd 찍어보믄 계정별로 결과가 쭈루루룩 나오는데, 뜻은 이거다. 계정:암호:UID:GID:정보:디렉토리:쉘 passwd 파일 설명은 ( http://www.linuweb.com/?p=248 ) 여기 님 블로그에 잘 되어있음. 암튼 결국 계정별로 cron 걸려있는거 죄다 찍어보니 for user in $(cut -f1 -d: /etc/passwd); do echo id $user; crontab -u $user -l ; done 한번에 다찍어주는 명령어는 따로 없나보다. 간단하게 스크립트로 찍어주는 수밖에. 결국 내가 찾던 cron은 처음보는 계정에 들어있었음. 그리고 cron이 안돌던 이유는 ftp가 막혀서였고 ㅋ