Sencha Touch-마이그레이션

Sencha Touch는 이전 버전의 다양한 수정 기능을 제공합니다.

Sencha Touch 2는 이전 버전과의 호환성 빌드와 함께 제공되므로 버전 1.x에서 2.x 로의 마이그레이션 프로세스가 더 쉬워집니다.

이 빌드는 마이그레이션 문제가 발생하거나 코드 변경이 필요할 때마다 경고와 로그를 제공하여 작업을 더 쉽게 만들어 주므로 사용자는 변경이 필요한 위치를 파악하여 애플리케이션이 최신 버전에서 작동하는지 확인합니다.

Sencha Touch 2.x 마이그레이션에는 다음 코드 변경이 필요합니다.

클래스 시스템

Code in Sencha Touch 1.x

MyApp.view.StudentPanel = Ext.extend(Ext.Panel, {
   scroll: 'vertical',
   html: 'Student Panel'
   initComponent: function() {
      Ext.getCmp('StudentIdDiv').update('This is a Student panel');
   }
});

Code in Sencha Touch 2.x

Ext.define('MyApp.view.StudentPanel', {
   extend: 'Ext.Panel',

   config: {
      scroll: 'vertical',
      html: 'Student Panel'
   },

   initialize: function() {
      Ext.getCmp('StudentIdDiv').setHtml('This is a Student panel')
   }
});

두 버전을 모두 살펴보면 클래스를 만드는 방법이 다음과 같은 ExtJ에서 영감을 얻은 변경 사항임을 알 수 있습니다.

  • Ext.extend가 Ext.define으로 변경되었습니다.

  • 이제 클래스와 관련된 모든 구성 매개 변수가 config 매개 변수 아래에 정의됩니다.

  • initComponent가 initialize () 메소드로 변경되었습니다.

  • Sencha Touch 2.x에서는 setHtml () 및 getHtml () 함수를 사용하여 html을 업데이트하거나 값을 가져올 수 있습니다.

MVC 아키텍처

Sencha Touch 1.x 코드는 모듈 식이며 MVC 아키텍처를 기반으로합니다. Sencha Touch 2.x는 모델,보기 및 컨트롤러 작성에 대해 다른 구문을 따릅니다. 다른 버전에서 모델,보기 및 컨트롤러 파일의 차이점을 살펴 보겠습니다.

모델

Code in Sencha Touch 1.x

Ext.regModel('MyApp.model.StudentModel', {
   fields: [
      {name: 'name',  type: 'string'},
      {name: 'age',   type: 'int'}
   ]
});

Code in Sencha Touch 2.x

Ext.define('MyApp.model.StudentModel', {
   extend: 'Ext.data.Model', config: {
      fields: [
         {name: 'name',  type: 'string'},
         {name: 'age',   type: 'int'}
      ]
   }
});

Ext.regModel이 Ext.data.Model을 확장하는 Ext.define으로 변경되었습니다.

모든 필드는 이제 2.x 버전에서 구성 섹션 아래에 있습니다.

전망

Code in Sencha Touch 1.x

Ext.Panel("studentView", {
   items: [{}]
});

Code in Sencha Touch 2.x

Ext.define('MyApp.view.StudentView', {
   extend: 'Ext.tab.Panel',
   items: [{}]
});

보기는 거의 동일하지만보기 이름은 Myapp.view.StudentView와 같은 2.x 버전 네임 스페이스를 따르고 코드는 Ext.define 메서드에서 모델처럼 작성된다는 점만 변경됩니다.

제어 장치

Code in Sencha Touch 1.x

Ext.regController("studentController", {
   someMethod: function() {
      alert('Method is called');
   }
});

Code in Sencha Touch 2.x

Ext.define('MyApp.controller.studentController', {
   extend: 'Ext.app.Controller', someMethod: function() {
      alert('Method is called');
   }
});

컨트롤러의 모델과 동일합니다. 또한 Ext.regController는 Ext.app.Controller를 확장하는 Ext.define으로 변경됩니다.

신청

Code in Sencha Touch 1.x

Ext.application({
   name: 'MyApp',
   launch: function() {
      Ext.create('MyApp.view.StudentView');
   }
});

Code in Sencha Touch 2.x

Ext.application({
   name: 'MyApp',
   models: ['studentModel'],
   controllers: ['studentController'],
   views: ['studentView'],
   stores: ['studentStore'],

   launch: function() {
      Ext.create('MyApp.view.Main');
   }
});

버전 1.x와 버전 2.x의 주요 차이점은 2.x에서 모든 모델, 뷰, 컨트롤러 및 저장소를 애플리케이션 자체에 선언한다는 것입니다.