• 분류 전체보기 (132)
    • 공지사항 (2)
    • 블로그팁 (4)
    • GKSkin (5)
      • 소개 (1)
      • 스킨다운로드 (1)
      • 사용법 (3)
    • GKTool (4)
      • 소개 (1)
      • 시연영상 (3)
    • 코드저장소 (41)
      • javascript (2)
      • jQuery 플러그인 (7)
      • java (12)
      • sql (10)
      • mybatis(ibatis) (3)
      • 스마트에디터연동 (3)
      • 다음에디터연동 (2)
      • 샘플링답변 (2)
    • 웹개발강좌 (48)
      • jQuery (8)
      • jQueryUI (5)
      • ExtJS (28)
      • 부트스트랩 (7)
    • 모바일웹강좌 (1)
      • SenchaTouch (1)
    • 개발에필요한연동법 (27)
      • 스프링연동 (16)
      • 리눅스서버구축 (11)
댓글
/44
2014. 10. 20. 19:00
ExtJS 강좌 - 지원해주는 레이아웃 알아보기(Absolute,Accordion,Border)

ExtJS의 레이아웃종류는 약 11종류를 제공해줍니다.


 Absolute, Accordion, Border, Card, Tab, Fit, Hbox/Vbox, Table/Center/Column Layout 

이번장에서는 각 레이아웃별 간단한 설명 및 Absolute,Accordion,Border레이아웃에 대한 

샘플 코드 및 실행결과에 대하여 알아보도록 하겠습니다.


Absolute Layout

레이아웃명칭 그대로 절대적으로 레이아웃이 위치에 정해지면 브라우저 화면 사이즈가 바뀌더라도 지정된 위치에 fix 되는 레이아웃입니다.

특이한 경우를 제외하고는 잘 사용하지 않는 레이아웃입니다 ^^


Accordion Layout

jQueryUI에서도 제공되는 어코디언 레이아웃입니다.

어코디언을 사용할 경우는 여러개의 컨텐츠(?)들을 한화면에 뿌리기에 부담이 될 경우 사용하시면 되겠습니다.

한번의 클릭당 하나의 컨텐츠를 시각적으로 확인하기 깔끔한 레이아웃입니다.

제 블로그의 스킨에도 사용된 부분은 좌측에 위젯관련 사이드바에 적용이 되었습니다.


Border Layout

이 레이아웃은 초기에 화면의 전체 레이아웃을 잡는데 유용한 레이아웃입니다.

"Border"를 사용하게 되면 Header/Footer/Side 등의 구조를 쉽게 잡게 해줍니다.

거의 ExtJS의 필수로 알아야하는 레이아웃(?) 이라고 저는 생각합니다.


Card Layout

카드레이아웃은 컨텐츠 내용의 화면 전환을 하는것이라고 생각하시면 되겠습니다.

예를들면 스마트폰 어플화면에서 메뉴 또는 게시판 목록의 내용을 클릭하면 화면이 스르륵 슬라이드 되면서 다른 내용의 페이지로 이동이 되는기능을 자주 보셨을 것인대

비슷한 기능이라 생각하시면 될것입니다.


Tab Layout

탭기능은 따로 말씀드리지 않아도 되나 탭 레이아웃 역시 카드레이아웃과 동일한 레이아웃구조입니다.

탭과카드레이아웃의 차이점이라면 탭바의 존재유무정도겠네요.


Fit Layout

화면을 꽉채우는 레이아웃입니다.

이 레이아웃 역시 Border와 같이 자주 사용되는 레이아웃입니다.

Fit이라는 레이아웃을 사용될경우, 현재 지정된 상단부모의 영역에 맞추어 자동으로 사이즈를 채워주는 역할을 하는 레이아웃입니다.

글로는 설명드리기는 애매하지만 이후 예를 들면서 진행시 서서히 이해가 가실것입니다.


HBox/VBox Layout

HBox : 패널들을 가로로 출력시켜주는 레이아웃

VBox : 패널들을 세로로 출력시켜주는 레이아웃

이 레이아웃들은 로그인 또는 회원가입등 폼 구조를 잡아줄때 주로 사용을 합니다.


Table/Center/Column Layout

위처럼 나머지 3개의 레이아웃이 존재하는데 이 레이아웃들의 데핸 설명은 제외하도록 하겠습니다.

슬퍼3

저도 사용해본적이 없어서 전달드리기가 애매~해서입니다 ;;


위와같이 다양한 레이아웃을 ExtJS에서는 제공을 해주고 있습니다.


실제로 코드 작성전에 밑의 내용을 꼭 이해해주셨으면 좋겠습니다.


※ ExtJS의 컴포넌트 생성의 경우 JSON 규격으로 KEY/VALUE값으로만으로 생성이 가능합니다.

    (기존의 일반 스크립트를 이용하여 구현했던 분들에게는 이해하기 약간 난해하실수 있습니다.)


그렇다면 이제 각 레이아웃의 이해를 돕고자 레이아웃관련 샘플코드를 몇가지 작성해보도록 하겠습니다.

레이아웃을 그리기기전에 도화지나 A4용지와 같은 역할을 해주는 껍데기가 있어야 하겠죠?

도화지 역할을 해주는 컴포넌트들은 'panel', 'container', 'viewport'  3가지정도로 요약할 수 있겠습니다.


container같은 경우는 저는 거의 사용을 하지 않고 

 최상단 부모 껍데기를 제작하고자 할 경우에는 viewport를 사용하고 

viewport의 자식 레이아웃을 그릴경우에는 panel을 사용합니다.


어떠한 껍데기로 생성하여 컴포넌트를 그릴지는 스스로 결정을 하시길 바랍니다.


그럼 지난강좌 INCLUDE를 기본적으로 한 CSS/JS파일이 존재한다 가정하고 레이아웃을 그려보도록 하겠습니다.


연동법은 하단 포스팅을 참고해주세요


2014/10/18 - [웹개발강좌/ExtJS] - ExtJS 강좌 - ExtJS5를 이용한 설치 및 연동하기 편



그럼 제일먼저 Absolute Layout에 대하여 예를 들어보도록 하겠습니다.


ExtJS 사이트의 샘플코드는 Ext.panel.Panel이란 도화지에 생성하여 

예를들지만 저같은 경우에는 viewport라는 도화지를 이용하여 예를 들도록 하겠습니다.

viewport 도화지의 장점이라 하면, 별도의 높이속성을 지정하지 않아도 

가로/세로의 간격이 자동으로 브라우저의 100%를 채워줍니다.



Absolute Layout 샘플코드

Ext.onReady(function(){
		//도화지가 되는 Panel컴포넌트 생성
		Ext.create("Ext.container.Viewport",{
			//도화지를 그려놓을 위치(Ext.getBody()의미 : <body>태그내에 그린다)
			renderTo : Ext.getBody(),
			//absolute 레이아웃
			layout : 'absolute',
		    items:[
		           {
		        	   //패널의 제목
		               title: '첫번째 패널',
		               //패널의 x,y 좌표위치
		               x: 50,
		               y: 50,
		               //패널의 Body영역에 들어갈 HTML내용
		               html: 'x좌표 50/y좌표 50',
		               //패널의 넓이/높이
		               width: 200,
				       height: 100,
				       //테두리두께 옵션
				       frame: true
		           },
		           {
		        	   //패널의 제목
		               title: '두번째패널',
		               //패널의 x,y 좌표위치
		               x: 125,
		               y: 125,
		               //패널의 Body영역에 들어갈 HTML내용
		               html: 'x좌표 125/y좌표 125',
		               //패널의 넓이/높이
		               width: 200,
				       height: 100,
				       //테두리두께 옵션
				       frame: true
		           }
		       ]
		});
	})


Absolute Layout 결과





위처럼 절대좌표로 인해서 겹쳐지는 화면을 확인 할수 있습니다.

설명을 드리자면 Ext.create부분에 panel 객체를 하나 생성 후 items 하단내에 sub 컴포넌트들을 2개 정의하였습니다.

흰바탕이 도화지 역할을 하는 첫번째 viewport객체이고 

items 내부에 각 x/y좌표 및 title/html등의 옵션을 준  panel 컴포넌트들이 도화지 위에 그려진 것입니다.

items내에 xtype이란것이 지정되지 않았지만 지정을 하지 않으셨다면 

기본 레이아웃의 xtype은  panel로 인식되니 xtype 속성을 붙여주셔도 무관합니다.

여기서 xtype이란 쉽게말해서 html태그들과 유사한 개념이라고 이해하시면 되겠습니다.


Accordion Layout 샘플코드

Ext.onReady(function(){
		//도화지가 되는 Panel컴포넌트 생성
		Ext.create("Ext.container.Viewport",{
			//도화지를 그려놓을 위치(Ext.getBody()의미 : <body>태그내에 그린다)
			renderTo : Ext.getBody(),
			//absolute 레이아웃
			layout : 'accordion',
		    items:[
		           {
		        	   //패널의 제목
		               title: '두번째 accordion 타이틀',
		               //패널의 내용
		               html: '첫번째 accordion 내용'
		           },
		           {
		        	   //패널의 제목
		               title: '첫번째 accordion 타이틀',
		               //패널의 내용
		               html: '두번째 accordion 내용'
		           }
		       ]
		});
	})

Accordion Layout 실행결과



어코디언 레이아웃은 위와같이 접히고 펼치는 효과로 인하여 

컨텐츠내용이 하나씩 보여지는것이 가능한것을 확인하였습니다.

Border Layout 샘플코드

해당 코드는 레이아웃구조를 정하는데 자주 사용되는 방식이니 코드작성 후 

각 속성별 상세 설명을 들어가도록 하겠습니다.


Ext.onReady(function(){
	//도화지가 되는 Panel컴포넌트 생성
	Ext.create("Ext.container.Viewport",{
		//도화지를 그려놓을 위치(Ext.getBody()의미 : <body>태그내에 그린다)
		renderTo : Ext.getBody(),
		//absolute 레이아웃
		layout : 'border',
	    items:[
	           {
	        	   //헤더(header)
	        	   region : 'north',
	        	   //패널의 제목
	               title: '상단 타이틀',
	               border : true,
	               //패널의 내용
	               html: '상단 내용'
	           },
	           {
	        	   //중앙
	        	   region : 'center',
	        	   //패널의 제목
	               title: '중앙 타이틀',
	               border : true,
	               //패널의 내용
	               html: '중앙 내용'
	           },
	           {
	        	   //풋터(footer)
	        	   region : 'south',
	        	   //패널의 제목
	               title: '하단 타이틀',
	               border : true,
	               //패널의 내용
	               html: '하단 내용'
	           },
	           {
	        	   //좌측사이드
	        	   region : 'west',
	        	   //패널의 제목
	               title: '좌측 타이틀',
	               border : true,
	               //패널의 내용
	               html: '좌측 내용'
	           },
	           {
	        	   //우측사이드
	        	   region : 'east',
	        	   //패널의 제목
	               title: '우측 타이틀',
	               border : true,
	               //패널의 내용
	               html: '우측 내용'
	           }
	       ]
	});
})

도화지의 자식격인 items내에 패널의 속성중 region이라는 속성값이 존재합니다.

이 속성값이 각각의 위치를 잡아주는 속성값입니다.

영단어라서 어디에 위치하는것인지는 쉽게 이해가 가실것입니다.


north : 북,center : 중앙,south : 남,west : 서,east : 동


"border:true"  속성을 준 이유는 영역의 구분을 눈으로 확인하고자 지정해준것입니다.

영역구분이 보기가 싫으신분이시라면 border:true를 제거 혹은 border:false를 주시면 되겠습니다.


Border Layout 실행결과





글이 길어지면 지루해지겠죠? 

나머지 레이아웃에 대한 설명은 다음장에 이어서 진행하도록 하겠습니다.


다음 포스팅에 다룰 레이아웃 종류

 Card,Tab,Fit,Hbox/Vbox Layout


Bye


by 개발로짜

저작자표시 비영리 변경금지 (새창열림)

'웹개발강좌 > ExtJS' 카테고리의 다른 글

ExtJS 강좌 - 다이얼로그창을 이용하여 깔끔하게 종류별로 메시지창 띄워보기  (4) 2014.10.23
ExtJS 강좌 - 메뉴버튼을 포함한 다양한 버튼컴포넌트 구현해보기  (4) 2014.10.22
ExtJS 강좌 - 툴바위치 및 버튼 클릭 이벤트 알아보기  (0) 2014.10.21
ExtJS 강좌 - 지원해주는 레이아웃 알아보기(Card,Tab,Fit,HBox/VBox)  (0) 2014.10.20
ExtJS 강좌 - ExtJS5를 이용한 설치 및 연동하기 편  (0) 2014.10.18

티스토리툴바