JavaScript/Backbone.js
Marionette.js Region 을 통한 Life Cycle 관리
devsh
2015. 2. 27. 17:59
728x90
반응형
Marionette.js Region 을 통한 Life Cycle 관리
Marionette의 Region 객체는 view의 render나 jQuery 객체의 html()을 사용하여 DOM에 뷰를 삽입하는 코드역시
보일러 플레이트 코드로 보고 이를 제거해준다.
- 보일러 플레이트 코드
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | var Sanghoon = new Person({ firstName: '이', lastName: '상훈', email: 'devsh@nara.co.kr' }); var MyView = Marionette.ItemView.extend({ template: '#my-view-template' }); var myView = new MyView({ model: Sanghoon }); myView.render(); // DOM에 뷰를 넣는다. $('#content').html(myView.el); | cs |
- Region 이용
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 | var Sanghoon = new Person({ firstName: '이', lastName: '상훈', email: 'devsh@nara.co.kr' }); var MyView = Marionette.ItemView.extend({ template: '#my-view-template' }); var myView = new MyView({ model: Sanghoon }); // Region 인스턴스를 만들고, 어떤 DOM 엘리먼트를 관리할지 지정한다. var myRegion = new Marionette.Region({ el: '#content' }); // Region 내의 뷰를 보여준다. var view1 = new MyView(); myRegion.show(view1); // 이 코드 어디선가 다른 뷰를 보여준다. var view2 = new MyView(); myRegion.show(view2); | cs |
얼핏봐서는 코드가 더 늘어난것 처럼 보일수도있겠다. 하지만 region객체를 이용하면 더이상 render 메서드를 호출할필요가없다 show() 메서드 내부에서 render() 를 호출 하고 뷰의 el을 가지고와서 DOM엘리먼트에 추가시킨다. 거거이ㅔ 고스트뷰가 되지않도록 show() 메서드 내에서 이벤트를 close 시킨다.
Marionette.View 가아닌 Backbone.View 를 사용하였다 하더라도 close 구현체가 존재하지 않는다면 Backbone.View의 내장 메서드인 remove를 호출하여 이벤트를 안전하게 제거한다.
728x90
반응형