Sencha Touch-역사 지원

Sencha Touch는 전체 히스토리 지원 및 딥 링크 기능을 제공합니다.

가장 간단한 뒤로 버튼 기능이있어 사용자가 페이지 또는 애플리케이션을 새로 고치지 않고도 화면 사이를 이동할 수 있습니다.

또한 사용자가 모든 URL로 이동하는 데 도움이되는 경로 기능을 제공합니다. 브라우저 창에 제공된 URL을 기반으로 특정 기능을 호출하여 특정 작업을 수행합니다.

뒤로 버튼 기능에 대한 다음 예제를보십시오.

이 예제는 목록 안에있는 목록에 불과한 중첩 된 목록을 보여 주므로 목록 항목 중 하나를 클릭하면 다른 목록이 열리고 화면 상단에 뒤로 버튼이 나타납니다.

전체 코드베이스 를 보려면보기 구성 요소 섹션에서 중첩 목록을 확인할 수 있습니다 .

라우팅

경로의 가장 간단한 예

Ext.define('MyApp.controller.Main', {
   extend: 'Ext.app.Controller',

   config: {
      routes: {
         login: 'showLogin',
		 'user/:id': 'userId'
      }
   },

   showLogin: function() {
      Ext.Msg.alert('This is the login page');
   },
   userId: function(id) {
      Ext.Msg.alert('This is the login page specific to the used Id provided');
   }
});

위의 예에서 브라우저 URL이 https://myApp.com/#login이면 showLogin 함수가 호출됩니다.

URL에 매개 변수를 제공하고 함수가 호출 될 수있는 특정 매개 변수를 기반으로합니다. 예를 들어 URL이 https://myApp.com/#user/3이면 다른 함수 userId가 호출되고 함수 내에서 특정 ID를 사용할 수 있습니다.

사전 라우팅

때로는 쉼표, 공백 및 특수 문자 등을 포함하는 사전 매개 변수가 있습니다. 위의 경로 작성 방법을 사용하면 작동하지 않습니다. 이 문제를 해결하기 위해 Sencha touch는 매개 변수가 수용해야하는 데이터 유형의 조건을 지정할 수있는 조건부 라우팅을 제공합니다.

Ext.define('MyApp.controller.Main', {
   extend: 'Ext.app.Controller', config: {
      routes: {
         login/:id: {
            action: showLogin, conditions: {':id: "[0-9a-zA-Z\.]+" }      
         }
      },

      showLogin: function() {
         Ext.Msg.alert('This is the login page with specific id which matches criteria');
      }     
   }
});

따라서 위의 예에서와 같이 URL 매개 변수로 허용해야하는 데이터 유형을 명확하게 나타내는 조건에서 정규식을 제공했습니다.

다른 장치 프로필에서 동일한 URL 공유

Sencha touch는 장치 프로파일을 제공하므로 동일한 애플리케이션 코드를 여러 장치에서 사용할 수 있으므로 다른 프로파일이 동일한 URL에 대해 다른 기능을 가질 수 있습니다.

이 문제를 해결하기 위해 Sencha touch는 메인 컨트롤러에서 라우팅을 작성할 수있는 자유를 제공하고 호출 된 함수는 프로파일 특정 프로파일로 모든 프로파일에 작성됩니다.

Ext.define('MyApp.controller.Main', {
   extend: 'Ext.app.Controller', config: {
      routes: {
         login: 'showLogin'
      }
   },
});
// For phone profile
Ext.define('MyApp.controller.phone.Main, {
   extend: 'MyApp.controller.Main, showLogin: function() {
      Ext.Msg.alert('This is the login page for mobile phone profile');
   }
});
// For tablet profile
Ext.define('MyApp.controller.tablet.Main, {
   extend: 'MyApp.controller.Main,showLogin: function() {
      Ext.Msg.alert('This is the login page for tablet profile');
   }
});

예를 들어 showLogin 기능이있는 하나의 메인 컨트롤러와 두 개의 서로 다른 프로필 (Phone / Tablet)이 있습니다. 두 프로필 모두 프로필에 따라 다른 코드를 사용하는 showLogin 기능이 있습니다.

이렇게하면 특정 기능을 가진 여러 프로필 장치에서 동일한 URL을 공유 할 수 있습니다.