블로그 이미지
올해목표 // 10월 어학연수 떠나자~ 자수씨

카테고리

전체글 (1457)
Brand New! (28)
주절주절 (213)
MOT (11)
해외쇼핑 (49)
쇼핑노트 (150)
취미생활 (94)
iPhone (4)
Eclipse (121)
Google (83)
Spring (31)
JAVA (176)
JavaScript (59)
WEB (49)
Database (20)
OS (26)
Tools (8)
Tips (26)
IT정보 (1)
Book (21)
Programming (37)
외부행사 (43)
주변인들 (17)
여행노트 (60)
학교생활 (30)
회사생활 (52)
사회생활 (5)
외국어공부 (12)
잡동사니 (30)
Total
Today
Yesterday
 
01-03 22:40
 

달력

« » 2025.1
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
 

최근에 올라온 글

최근에 달린 댓글


2011/09/12 - [JavaScript/ExtJS] - Ext JS 4 시작하기 (1)
2011/09/13 - [JavaScript/ExtJS] - Ext JS 4 시작하기 (2)
2011/09/13 - [JavaScript/ExtJS] - Ext JS 4 시작하기 (3)

그리드 제어하기

'onPanelRendered' 함수는 여전히 호출되고 있습니다. 'viewport > panel' 셀렉터에 의해서 동작을 하게 됩니다. 우리가 생성한 List 클래스는 그리드를 상속받았는데, 그리드는 패널을 상속받았기 때문입니다.


'Vicki.view.user.List' 클래스만 컨트롤 하도록 컨트롤러를 수정합니다.
[수정] app/controller/Users.js
01Ext.define('Vicki.controller.Users', {
02    extend: 'Ext.app.Controller',
03 
04    views: [
05        'user.List'
06    ],
07 
08    init: function() {
09        this.control({
10            'userlist': {
11                itemdblclick: this.editUser
12            }
13        });
14    },
15 
16    editUser: function(grid, record) {
17        console.log(record.get('name') + '이(가) 더블클릭 되었습니다.');
18    }
19});


컴포넌트 셀렉터의 'userlist' 는 alias 가 'userlist' 정의된 클래스의 인스턴스들을 처리하게 됩니다.




수정 윈도우 추가하기

그리드 데이터를 수정할 수 있는 윈도우 클래스를 생성합니다.

[추가] app/view/user/Edit.js

01Ext.define('Vicki.view.user.Edit', {
02    extend: 'Ext.window.Window',
03    alias : 'widget.useredit',
04 
05    title : 'Edit User',
06    layout: 'fit',
07    autoShow: true,
08 
09    initComponent: function() {
10        this.items = [
11            {
12                xtype: 'form',
13                items: [
14                    {
15                        xtype: 'textfield',
16                        name : 'name',
17                        fieldLabel: 'Name'
18                    },
19                    {
20                        xtype: 'textfield',
21                        name : 'email',
22                        fieldLabel: 'Email'
23                    }
24                ]
25            }
26        ];
27 
28        this.buttons = [
29            {
30                text: 'Save',
31                action: 'save'
32            },
33            {
34                text: 'Cancel',
35                scope: this,
36                handler: this.close
37            }
38        ];
39 
40        this.callParent(arguments);
41    }
42});


'Ext.window.Window' 클래스를 상속받았으며, alias 는 'widget.useredit' 로 등록되었습니다. 추후에 xtype 'useredit' 로 로딩이 가능합니다. autoShow 속성이 true 로 설정되어 생성되는 즉시 보여지게 됩니다.

윈도우 내부에는 이름과 이메일 필드가 포함된 'form' 으로 구성되었습니다.

[수정] app/controller/Users.js
01Ext.define('Vicki.controller.Users', {
02    extend: 'Ext.app.Controller',
03 
04    views: [
05        'user.List',
06        'user.Edit'
07    ],
08 
09    init: ...
10 
11    editUser: function(grid, record) {
12        var view = Ext.widget('useredit');
13 
14        view.down('form').loadRecord(record);
15    },
16     
17});


views 에 'user.Edit' 를 추가하고 editUser 함수를 수정합니다.
Ext.widget('useredit') 라는 함수를 이용하여 'Vicki.view.user.Edit' 인스턴스를 생성할 수 있습니다.
윈도우 내부 form 패널에 그리드에서 선택된 레코드 정보를 채워주게 됩니다.


down(String selector, [Boolean returnDom]) 함수는 CSS 셀렉터를 기반으로 자식요소를 검색합니다.





파일구조

지금까지 작업에 대한 파일구조는 아래와 같습니다.




참고자료

http://docs.sencha.com/ext-js/4-0/#!/guide/application_architecture


Posted by 자수씨
, |

글 보관함

최근에 받은 트랙백