Sencha Touch-퀵 가이드

Sencha Touch는 모바일 애플리케이션 용 사용자 인터페이스를 만들기위한 Sencha의 인기있는 프레임 워크입니다. 개발자가 Android, IOS, BlackBerry 및 Windows와 같은 많은 모바일 장치를 지원하는 간단한 HTML, CSS, JS를 사용하여 모바일 앱을 만드는 데 도움이됩니다. MVC 아키텍처를 기반으로합니다. Sencha Touch의 최신 버전은 2.4입니다.

센차 터치의 역사

웹 애플리케이션 용인 Sencha의 다른 제품인 ExtJs를 출시 한 후 모바일 장치에서도 작동하는 프레임 워크를 개발해야했습니다.

Sencha Touch의 첫 번째 버전은 Android 및 IOS 기기를 지원하는 0.9 베타 버전이었습니다. 나중에 Sencha Touch 버전 1.0의 첫 번째 메인 릴리스는 2010 년 11 월에 있었는데, 이는 첫 번째 안정 버전이었고 Blackberry 장치도 지원했습니다.

Sencha Touch의 최신 릴리스는 2015 년 6 월에 출시 된 버전 2.4로, Windows, Tizen과 함께 Android, IOS, BlackBerry OS 10, Android 용 Google Chrome 및 모바일 Safari 등과 같은 다양한 장치를 지원합니다.

Sencha Touch의 특징

다음은 Sencha Touch의 가장 눈에 띄는 기능입니다-

  • 모바일 플랫폼을 위해 특별히 제작 된 목록, 캐 러셀, 양식, 메뉴 및 도구 모음과 같은 풍부한 UI 모음을 사용하여 사용자 정의 가능하고 50 개 이상의 UI 위젯을 빌드합니다.

  • 새 버전과 이전 버전의 코드 호환성.

  • 다양한 OS를 사용하는 여러 모바일 장치에서 데이터 및 콘텐츠 표시를 구성하는 데 도움이되는 유연한 레이아웃 관리자입니다.

  • 프레임 워크에는 모든 백엔드 데이터 소스의 데이터를 사용할 수있는 강력한 데이터 패키지가 포함되어 있습니다.

  • 더 나은 모바일 웹 애플리케이션 경험을위한 적응 형 레이아웃, 애니메이션 및 부드러운 스크롤.

  • 모든 주요 플랫폼에 대한 기본 제공 테마를 사용하면 웹 및 하이브리드 애플리케이션을 대상 플랫폼의 모양과 느낌과 일치시킬 수 있습니다.

Sencha Touch ─ 장점

Sencha Touch는 비즈니스 급 웹 애플리케이션 개발을위한 선도적 인 표준입니다. 응용 프로그램 개발을위한 단일 플랫폼을 제공하는 대부분의 모바일 장치를위한 강력한 응용 프로그램을 구축하는 데 필요한 도구를 제공합니다. 다음은 몇 가지 이점입니다.

  • 반응 형 터치 기능을 제공하므로 사용자가 모바일 앱을 사용하는 동안 쉽게 탐색 할 수 있습니다.

  • 모든 최신 버전의 IOS, Android 및 Blackberry, Windows와의 호환성을 제공합니다.

  • 모든 모바일 애플리케이션에 적합한 가능한 가장 빠른 속도를 제공합니다.

  • 크로스 플랫폼 호환성으로 비용 효율적인 솔루션을 제공합니다.

  • 개발자가 Sencha Touch를 더 쉽게 이해할 수 있도록 기본 API 및 HTML, CSS, JS와 같은 기본 웹 개발 언어를 기반으로합니다.

Sencha Touch ─ 제한 사항

Sencha Touch API에는 다음 기능이 없습니다.

  • 앱이 기기의 카메라, 연락처 및 가속도계에 액세스 할 수 없습니다.

  • 푸시 알림 기능을 제공하지 않습니다. 이를 위해 웹 소켓 또는 긴 폴링을 사용해야합니다.

  • 일반 공용 라이센스 정책에 따라 오픈 소스 애플리케이션의 경우 무료이지만 상업용 애플리케이션의 경우 유료입니다.

  • 게임 앱과 같은 하드 코어 그래픽 및 애니메이션 앱에는 적합하지 않습니다.

Sencha Touch ─ 도구

Sencha SDK

이것은 프로젝트의 골격을 만드는 데 사용되는 Sencha 개발 키트입니다. "sencha -sdk path / to / touch generate app appName"명령을 사용하여 명령에 지정된 이름으로 앱을 만듭니다.

앱이 생성되면 앱에서 다음 파일을 볼 수 있습니다.

  • app −이 폴더에는 앱의 모델,보기, 컨트롤러 및 스토어 파일이 포함되어 있습니다.

  • app.js− 이것은 애플리케이션의 주요 JS 파일입니다. 이 파일에서 Sencha 코드 흐름이 시작됩니다.

  • app.json − 이것은 앱의 구성 파일이며 여기에 모든 구성 세부 정보가 표시됩니다.

  • index.html − app.js 및 기타 Sencha 관련 파일이 포함 된 기본 html 파일입니다.

  • package.json −이 파일에는 앱과 관련된 모든 종속성 및 기타 정보가 있습니다.

  • resources −이 폴더에는 응용 프로그램에 필요한 모든 CSS 파일과 이미지가 포함되어 있습니다.

센차 CMD

Sencha CMD는 Sencha Touch 코드 축소, 스캐 폴딩, 빌드 생성 및 프로덕션 목적의 기타 유용한 기능을 제공하는 명령 줄 도구입니다.

이를 위해 애플리케이션을 빌드하기 위해 명령 프롬프트에서 "Sencha app build package"명령을 사용합니다. 명령 프롬프트에서 앱 디렉토리로 이동하여 위의 명령을 입력하십시오. 빌드가 성공하면 기본적으로 프로덕션 용도로 사용되는 애플리케이션의 축소 된 버전이 표시됩니다.

다음에서 다운로드 할 수 있습니다. https://www.sencha.com/products/extjs/cmd-download/

Sencha 검사관

Sencha Inspector는 개발 중에 Sencha 코드의 모든 문제를 디버깅하는 디버깅 도구입니다.

지역 환경 설정

이 섹션에서는 컴퓨터에서 Sencha Touch를 다운로드하고 설정하는 방법에 대해 설명합니다. 환경 설정 단계를 따르십시오.

라이브러리 파일 다운로드

다음 링크에서 Sencha Touch 라이브러리 파일의 상용 버전을 다운로드하십시오. https://www.sencha.com. sencha-touch-2.4.2-commercial이라는 압축 폴더 인 등록 된 메일 ID의 사이트에서 평가판을받을 수 있습니다.

폴더의 압축을 풀면 애플리케이션에 포함 할 다양한 JavaScript 및 CSS 파일을 찾을 수 있습니다. 대부분 다음 파일 포함-

Javascript Files − \ sencha-touch-2.4.2commercial \ touch-2.4.2 폴더에서 찾을 수있는 JS 파일은 −

Sr. 아니요 파일 설명
1

sencha-touch.js

애플리케이션을 실행하기위한 모든 기능이 포함 된 핵심 파일입니다.

2

sencha-touch-all.js

이 파일에는 파일에 주석없이 축소 된 모든 코드가 포함되어 있습니다.

sencha-touch-debug.js

이것은 디버깅 목적으로 sencha-touch-all.js의 축소되지 않은 버전입니다.

4

sencha-touch-all-debug.js

이 파일은 또한 축소되지 않으며 오류 / 문제를 확인하기위한 모든 주석 및 콘솔 로그를 포함하므로 개발 목적으로 사용됩니다.

이러한 파일을 프로젝트 JS 폴더에 추가하거나 파일이 시스템에있는 직접 경로를 제공 할 수 있습니다.

CSS Files − I : \ sencha touch \ sencha-touch-2.4.2-commercial \ touch-2.4.2 \ resources \ css \ sencha-touch.css 폴더에 테마 기반 파일이 많이 있습니다.

이러한 라이브러리 파일은 다음과 같이 Sencha Touch 애플리케이션에 추가됩니다.

<html>
   <head>
      <script type = "text/javascript" src = "../sencha-touch-2.4.2-commercial/touch-2.4.2/sencha-touch-all.js"></script>  
      <link href = "../sencha-touch-2.4.2-commercial/touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type ="text/javascript" src = "app.js" > </script> 
   </head>
</html>

Sencha Touch 애플리케이션 코드는 app.js 파일에 보관할 수 있습니다.

CDN 설정

CDN은 Sencha Touch 라이브러리 파일을 다운로드 할 필요가없는 콘텐츠 전송 네트워크입니다. 대신 다음과 같이 ExtJS 용 CDN 링크를 프로그램에 직접 추가 할 수 있습니다.

<html>
   <head>
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>    
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel="stylesheet" />
      <script type = "text/javascript" src = "app.js" > </script> 
   </head>
</html>

인기있는 편집자

웹 애플리케이션 개발에 사용되는 JavaScript 프레임 워크이므로 프로젝트에는 HTML, JS 파일이 있으며 Ext JS 프로그램을 작성하려면 텍스트 편집기가 필요합니다. 시장에는 여러 IDE가 있습니다. 그러나 지금은 다음 중 하나를 고려할 수 있습니다.

  • Notepad − Windows 컴퓨터에서는 메모장 (이 자습서에 권장 됨), Notepad ++와 같은 간단한 텍스트 편집기를 사용할 수 있습니다.

  • Brackets − 다운로드 할 수있는 또 다른 인기 IDE http://brackets.io/ .

  • Sublime − 다운로드 할 수있는 또 다른 인기 IDE https://www.sublimetext.com/3/ .

Naming convention식별자에 따라야 할 규칙 집합입니다. 다른 프로그래머도 코드를 쉽게 읽고 이해할 수 있도록합니다.

Sencha Touch의 이름 지정 규칙은 표준 JavaScript 규칙을 따르며, 이는 필수는 아니지만 따라야 할 좋은 방법입니다. 클래스, 메서드, 변수 및 속성의 이름을 지정하려면 낙타 케이스 구문을 따라야합니다.

이름이 두 단어로 결합되면 두 번째 단어는 항상 대문자로 시작됩니다. 예를 들어 doLayout (), StudentForm, firstName 등입니다.

Sr. 아니. 이름 및 컨벤션
1

Class Name

대문자로 시작하고 뒤에 카멜 케이스가 와야합니다. 예 : StudentClass

2

Method Name

소문자로 시작하고 뒤에 카멜 케이스가 와야합니다. 예 : studentMethod ()

Variable Name

소문자로 시작하고 뒤에 카멜 케이스가 와야합니다. 예 : studentName

4

Constant Name

대문자 여야합니다. 예 : COUNT, MAX_VALUE

5

Property Name

소문자로 시작하고 뒤에 카멜 케이스가 와야합니다. 예 : enableColumnResize = true

모든 모바일 애플리케이션의 최하위 계층은 OS이며 그 위에는 모든 것이 구축됩니다. 그런 다음 응용 프로그램을 실행할 브라우저가 있습니다. Chrome, Safari, IE 무엇이든 될 수 있습니다. 상위 계층은 모두에게 공통적 인 W3 표준입니다. Sencha Touch는 W3 표준을 기반으로 구축되거나 HTML5에 불과하므로 단일 응용 프로그램이 다양한 장치의 다른 브라우저와 호환됩니다.

Sencha Touch는 ExtJs, JqTouch 및 Raphael (벡터 드로잉)의 세 가지 프레임 워크의 조합입니다. MVC 아키텍처를 따릅니다. MVC는 코드를 더 관리하기 쉬운 청크로 분리합니다.

그러나 아키텍처가 프로그램에 필수는 아니지만 코드를 유지 관리하고 체계적으로 만들려면이 구조를 따르는 것이 좋습니다.

Sencha Touch 앱을 사용한 프로젝트 구조

----------src
----------resources
-------------------CSS files
-------------------Images
----------JavaScript
--------------------App Folder
-------------------------------Controller
------------------------------------Contoller.js
-------------------------------Model
------------------------------------Model.js
-------------------------------Store
------------------------------------Store.js
-------------------------------View
------------------------------------View.js
-------------------------------Utils
------------------------------------Utils.js
--------------------------------app.js
-----------HTML files

Sencha Touch 앱 폴더는 프로젝트의 JavaScript 폴더에 있습니다.

앱에는 app.js가있는 컨트롤러,보기, 모델, 저장소 및 유틸리티 파일이 포함됩니다.

app.js− 프로그램의 흐름이 시작될 메인 파일. <script> 태그를 사용하여 기본 HTML 파일에 포함되어야합니다. 앱은 나머지 기능을 위해 애플리케이션의 컨트롤러를 호출합니다.

Controller.js− Sencha Touch MVC 아키텍처의 컨트롤러 파일입니다. 여기에는 응용 프로그램의 모든 제어, 이벤트 리스너 및 대부분의 코드 기능이 포함됩니다. 다음 작업을 수행합니다 : 라우팅, 뷰와 모델 간의 중간, 이벤트 실행.

View.js− 사용자에게 표시되는 응용 프로그램의 인터페이스 부분을 포함합니다. Sencha Touch는 요구 사항에 따라 확장 및 사용자 정의 할 수있는 다양한 UI 리치 뷰를 사용합니다.

Store.js− 여기에는 모델 객체의 도움으로 뷰에 렌더링되는 로컬 캐시 데이터가 포함됩니다. Store는 백엔드 데이터를 가져 오기 위해 서비스에 대해 정의 된 경로가있는 프록시를 사용하여 데이터를 가져옵니다.

Model.js−보기 위해 매장 데이터를 바인딩하는 객체를 포함합니다. 기본적으로 데이터베이스를 다루는 실제 객체의 표현입니다.

Utils.js− MVC 아키텍처에는 포함되어 있지 않지만 코드를 깔끔하고 덜 복잡하며 읽기 쉽게 만들기 위해 이것을 사용하는 것이 가장 좋습니다. 이 파일에 메서드를 작성하고 필요할 때마다 컨트롤러 또는 뷰 렌더러에서 호출 할 수 있습니다. 코드 재사용 목적에도 도움이됩니다.

MVC는 Model View Controller의 약자입니다. 애플리케이션을 논리적 구성 요소로 분리하여 관리하기 쉽게 만드는 아키텍처 패턴입니다.

다음 다이어그램은 MVC 아키텍처가 작동하는 방식을 보여줍니다.

Controller − 컨트롤러는 전체 애플리케이션을 제어하여 모델이 변경되면 뷰에 알리고 사용자 입력에 따라 작업을 수행합니다.

View− 사용자에게 시각적 인 응용 프로그램의 인터페이스 부분을 포함합니다. 사용자 입력에 따라 모델 변경을 컨트롤러에 알립니다.

Model−보기 위해 매장 데이터를 바인딩하는 객체를 포함합니다. 기본적으로 데이터베이스를 다루는 실제 객체의 표현입니다. 또한 뷰의 변경 사항을 컨트롤러에 알립니다.

이 장에서는 Ext JS에서 첫 번째 Hello World 프로그램을 작성하는 단계를 나열합니다.

1 단계

선택한 편집기에서 index.htm 페이지를 만듭니다. 다음과 같이 html 페이지의 헤드 섹션에 필요한 라이브러리 파일을 포함하십시오.

index.htm

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js">
      </script>
      <script type = "text/javascript">
         Ext.application( {
            name: 'Sencha', launch: function() {
               Ext.create("Ext.tab.Panel", {
                  fullscreen: true, items: [{
                     title: 'Home', iconCls: 'home', html: 'Welcome to sencha touch'
                  }]
               });
            }
         });
      </script>
   </head>
   
   <body>
   </body>
</html>

설명

  • Ext.application () 메서드는 Sencha Touch 응용 프로그램의 시작점입니다. name 속성으로 선언 된 'Sencha'라는 전역 변수를 생성합니다. 모델, 뷰 및 컨트롤러와 같은 모든 응용 프로그램의 클래스는이 단일 네임 스페이스에 상주하므로 전역 변수와 파일 이름이 충돌 할 가능성이 줄어 듭니다.

  • 페이지가 준비되고 모든 JavaScript 파일이로드되면 launch () 메서드가 호출됩니다.

  • Ext.create () 메서드는 Sencha Touch에서 개체를 만드는 데 사용됩니다. 여기에서는 간단한 패널 클래스 Ext.tab.Panel의 객체를 생성합니다.

  • Ext.tab.Panel은 패널을 만들기 위해 Sencha Touch에서 미리 정의 된 클래스입니다.

  • 모든 Sencha Touch 클래스에는 몇 가지 기본 기능을 수행하기위한 서로 다른 속성이 있습니다.

Ext.Panel 클래스에는 다음과 같은 다양한 속성이 있습니다.

  • fullscreen 속성은 전체 화면을 사용하는 것이므로 패널은 전체 화면 공간을 차지합니다.

  • items property는 다양한 항목의 컨테이너입니다.

  • iconCls 다른 아이콘을 표시하는 데 사용되는 클래스입니다.

  • title 속성은 패널에 제목을 제공하는 것입니다.

  • html property는 패널에 표시 할 html 컨텐츠입니다.

2 단계

표준 브라우저에서 index.htm 파일을 열면 다음과 같은 출력이 표시됩니다.

웹 애플리케이션에 대한 오늘날의 요구는 적은 개발 노력으로 빠른 애플리케이션을 개발하는 것입니다. Sencha Touch는 사용자 지정 빌드를 생성하는 기능과 함께 개발 또는 프로덕션 코드를 기반으로 선택할 수있는 여러 빌드 라이브러리를 제공하므로이를 쉽게 수행 할 수 있습니다.

Sencha Touch 빌드 라이브러리는 클래스를 동적으로로드합니다. 동적 로딩은 필요할 때로드되는 클래스를 나타내며 애플리케이션에 필요한 클래스 만 포함됩니다. 이렇게하면로드 할 파일 수가 줄어들고 동시에로드 시간이 줄어들면서 응용 프로그램이 더 빠르게 실행됩니다.

Sencha Touch 2.x는 다음 5 개의 빌드 라이브러리를 제공합니다.

Sr. 아니. 빌드 및 사용
1

sencha-touchdebug.js

이 빌드는 애플리케이션을 로컬로 개발하는 동안 사용됩니다. 개발 중에 쉽게 디버깅 할 수 있도록 모든 주석 및 디버그 로그가 포함 된 축소되지 않은 버전입니다.

2

senchatouch.js

이 파일은 프로덕션 용도로 사용됩니다. 사용자 지정 빌드가있을 때 축소 된 버전입니다.

sencha-touchall.js

이 파일은 프로덕션 용도로 사용됩니다. 사용자 지정 빌드가없는 경우 축소 된 버전입니다.

4

sencha-touchall-debug.js

이 파일은 프로덕션에서 디버깅하는 데 사용됩니다. 축소되지 않으며 모든 주석 및 디버그 로그가 있습니다.

5

sencha-touchall-compat.js

이 빌드는 버전 1.x를 버전 2.x로 마이그레이션하는 데 사용됩니다. 버전 1.x 코드가 호환되지 않고 코드 수정이 필요한 경우 경고를 표시합니다.

위에서 언급 한 빌드를 통해 Sencha Touch는 사용자 지정 빌드를 만드는 기능을 제공합니다.

사용자 지정 빌드의 장점

사용자 지정 빌드는 모든 터치 파일을로드하지 않습니다. 응용 프로그램에서 사용중인 파일 만로드하므로 응용 프로그램을 더 빠르고 쉽게 유지 관리 할 수 ​​있습니다.

Sencha CMD는 사용자 지정 빌드를 만드는 데 사용됩니다. Sencha CMD에서 사용자 지정 빌드를 만들려면 앱 파일이있는 디렉터리로 이동하고 다음 명령 중 하나를 입력하여 빌드를 만듭니다.

Sr. 아니. 명령 및 사용법
1

sencha app build native

앱을 빌드하고 애플리케이션을 패키징하는 데 사용할 수있는 packager.temp.json이라는 파일을 준비합니다. packager.temp.json은 packager.json과 동일하지만 추가 경로를 포함합니다.

2

sencha app build -run native

애플리케이션을 빌드하고 자동으로 패키징하고 적절한 시뮬레이터를 시작합니다.

sencha app build package

패키징 지원을 사용하여 앱을 빌드하지만 패키저 JSON 파일을 구성하지 않습니다. 이는 여러 packager.json 파일을 수동으로 유지 관리하는 프로젝트에 유용합니다.

빌드가 성공하면 프로덕션 준비를 위해 index.html에 포함해야하는 all-classes.js 파일이 생성됩니다.

다음 코드는 프로덕션 준비 코드에 대해 수행 할 변경 사항을 보여줍니다.

Index.html before building application

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-debug.js"></script>
      <script type = "text/javascript" src = "app.js"> </script>
   </head>
   <body>
   </body>
</html>

Index.html after building the application

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch.js"></script>
      <script type = "text/javascript" src = "app.js"> </script>
      <script type = "text/javascript" src = "app-classes.js"> </script>
   </head>
   <body>
   </body>
</html>

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에서 모든 모델, 뷰, 컨트롤러 및 저장소를 애플리케이션 자체에 선언한다는 것입니다.

Sencha Touch는 클래스 시스템, 아약스, 컨트롤러 등과 같은 다양한 핵심 개념을 가지고 있습니다.

다음 표에는 Sencha Touch의 핵심 개념에 대한 링크가 나열되어 있습니다.

Sr. 아니. 개념 및 설명 링크
1 클래스 시스템
2 구성품
컨트롤러
4 BlackBerry 지원
5 Ajax 사용

Sencha Touch의 데이터 패키지는 데이터를 저장하거나로드하는 모든 종류의 데이터 조작을 수행합니다.

데이터 패키지는 모델, 저장소 및 프록시와 관련됩니다.

Sr. 아니. 개념 및 설명 링크
1

Model

UI에 모든 값을 표시하는 데 사용되는 데이터 및 필드 모음입니다. 기술

2

Store

기본적으로 데이터를 로컬에 저장하는 모델 인스턴스의 모음입니다. 스토어에서 우리는 모든 이벤트를 작성하고 데이터를 얻기 위해 나머지 호출을합니다. 기술

Proxy

기본적으로 저장소에 데이터를로드하는 역할을합니다. 대부분 우리는 ajax 프록시를 사용하여 저장소 데이터를로드합니다. 기술

Sencha Touch는 애플리케이션에서 사용할 수있는 다양한 테마를 제공합니다. 클래식 테마 대신 다른 테마를 추가하고 애플리케이션에 사용하는 장치에 따라 출력의 차이를 확인할 수 있습니다. 다음 예제에서 설명한대로 테마 CSS 파일을 바꾸면됩니다.

데스크탑 테마

첫 번째 Hello World 애플리케이션을 고려하십시오. 응용 프로그램의 다음 CSS는 데스크탑 테마에 사용됩니다.

https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css

효과를 확인하려면 다음 프로그램을 시도하십시오.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type="text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.application({
            name: 'Sencha',
            launch: function() {
               Ext.create("Ext.tab.Panel", {
                  fullscreen: true,
                  items: [{
                     title: 'Home',
                     iconCls: 'home',
                     html: 'Welcome to sencha touch'
                  }]
               });
            }
         });
      </script>
   </head>
</html>

이것은 다음 결과를 생성합니다-

Windows 테마

첫 번째 Hello World 애플리케이션을 고려하십시오. 응용 프로그램에서 다음 CSS를 제거하십시오-

https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css

Windows 테마를 사용하려면 다음 CSS를 추가하십시오.

https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/wp.css

효과를 확인하려면 다음 프로그램을 시도하십시오.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/wp.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.application({
            name: 'Sencha',
            launch: function() {
               Ext.create("Ext.tab.Panel", {
                  fullscreen: true,
                  items: [{
                     title: 'Home',
                     iconCls: 'home',
                     html: 'Welcome to sencha touch'
                  }]
               });
            }
         });
      </script>
   </head>
</html>

이것은 다음 결과를 생성합니다-

IOS 테마

첫 번째 Hello World 애플리케이션을 고려하십시오. 애플리케이션에서 다음 CSS를 제거하십시오.

https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css

Windows 테마를 사용하려면 다음 CSS를 추가하세요.

https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/cupertino.css

효과를 확인하려면 다음 프로그램을 시도하십시오.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/cupertino.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.application({
            name: 'Sencha',
            launch: function() {
               Ext.create("Ext.tab.Panel", {
                  fullscreen: true,
                  items: [{
                     title: 'Home',
                     iconCls: 'home',
                     html: 'Welcome to sencha touch'
                  }]
               });
            }
         });
      </script>
   </head>
</html>

이것은 다음 결과를 생성합니다-

IOS 클래식 테마

첫 번째 Hello World 애플리케이션을 고려하십시오. 응용 프로그램에서 다음 CSS를 제거하십시오-

https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css

Windows 테마를 사용하려면 다음 CSS를 추가하십시오.

https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/cupertino-classic.css

효과를 확인하려면 다음 프로그램을 시도하십시오.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/cupertino-classic.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.application({
            name: 'Sencha',
            launch: function() {
               Ext.create("Ext.tab.Panel", {
                  fullscreen: true,
                  items: [{
                     title: 'Home',
                     iconCls: 'home',
                     html: 'Welcome to sencha touch'
                  }]
               });
            }
         });
      </script>
   </head>
</html>

이것은 다음 결과를 생성합니다-

안드로이드 테마

첫 번째 Hello World 애플리케이션을 고려하십시오. 애플리케이션에서 다음 CSS를 제거하십시오.

https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css

Windows 테마를 사용하려면 다음 CSS를 추가하십시오.

https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/mountainview.css

효과를 확인하려면 다음 프로그램을 시도하십시오.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/mountainview.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.application({
            name: 'Sencha',
            launch: function() {
               Ext.create("Ext.tab.Panel", {
                  fullscreen: true,
                  items: [{
                     title: 'Home',
                     iconCls: 'home',
                     html: 'Welcome to sencha touch'
                  }]
               });
            }
         });
      </script>
   </head>
</html>

이것은 다음 결과를 생성합니다-

BlackBerry 테마

첫 번째 Hello World 애플리케이션을 고려하십시오. 애플리케이션에서 다음 CSS를 제거하십시오.

https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css

Windows 테마를 사용하려면 다음 CSS를 추가하십시오.

https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/bb10.css

효과를 확인하려면 다음 프로그램을 시도하십시오.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/bb10.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.application({
            name: 'Sencha',
            launch: function() {
               Ext.create("Ext.tab.Panel", {
                  fullscreen: true,
                  items: [{
                     title: 'Home',
                     iconCls: 'home',
                     html: 'Welcome to sencha touch'
                  }]
               });
            }
         });
      </script>
   </head>
</html>

이것은 다음 결과를 생성합니다-

오늘날의 기술 세계에서는 화면 크기가 다른 모바일, 태블릿, 데스크톱 및 노트북과 같은 여러 장치가 있습니다. 따라서 모양과 느낌이 좋은 모든 장치에서 액세스 할 수있는 응용 프로그램을 개발할 필요가 있습니다. 그러나 장치마다 다른 코드를 개발하려면 시간과 비용이 많이 듭니다.

Sencha Touch는 장치 프로필 기능을 제공하여 이와 관련하여 우리를 돕습니다. 활성 프로필을 기반으로 다양한 종속성이 실행되고 적용됩니다.

애플리케이션 코드를 작성하면서 디바이스 프로파일을 선언 할 수 있습니다. 우리는 여러 장치를 가질 수 있습니다.

Ext.application({
   name: 'MyApp',
   profiles: ['Phone', 'Tablet']
});

완료되면 프로필이 다음과 같이로드됩니다.

  • MyApp.profiles.Phone.js
  • MyApp.profiles.Tablet.js

간단한 전화 프로필 작성

Ext.define('Mail.profile.Phone', {
   extend: 'Ext.app.Profile',

   config: {
      name: 'Phone',
      views: ['phoneView']
   },

   isActive: function() {
      return Ext.os.is('Phone');
   }
});

간단한 태블릿 프로필 작성

Ext.define('Mail.profile.Tablet', {
   extend: 'Ext.app.Profile',

   config: {
      name: 'Tablet',
      views: ['tableView']
   },

   isActive: function() {
      return Ext.os.is('Tablet');
   }
});

프로필에서 볼 수 있듯이 특정 장치가 활성 상태인지 확인하는 isActive 기능이 있습니다. 장치가 활성 상태이면 해당 종속성이로드되고 인스턴스화됩니다.

위의 예에서 언급했듯이 전화 장치를 사용하는 경우 전화 프로필의 isActive 함수가 true를 반환하고 전화 장치와 관련된 종속성이로드됩니다. 여기에 phoneView가로드됩니다. 장치가 태블릿 인 경우 전화 프로필의 isActive 함수는 false를 반환하고 태블릿 프로필의 isActive 함수는 true를 반환하고 종속성 tabletView가로드됩니다.

시작 프로세스

여기서 주목해야 할 또 하나의 점은 애플리케이션에 프로필이있을 때 애플리케이션 코드의로드 및 인스턴스화가 다음 순서로 진행된다는 것입니다.

  • 컨트롤러가 먼저 인스턴스화되고 각 컨트롤러의 초기화 기능이로드됩니다.
  • 프로필의 시작 기능이 호출됩니다.
  • 응용 프로그램의 시작 기능이 호출됩니다.

프로필과 애플리케이션의 시작 함수는 모두 선택 사항이므로 둘 중 하나를 정의하지 않으면 호출되지 않습니다.

다른 시작 및 초기화 기능을 정의 할 수있는 위치와 방법을 확인하려면 다음 코드를 살펴보십시오.

컨트롤러의 초기화 기능

Ext.define('MyApp.controller.Main', {
   extend: 'Ext.app.Controller',
   
   init : function (){
      Ext.Msg.alert('Controller's init method');
   },
   
   config: {
      refs: {
         tab: '#divId
     }
   }
});

프로필의 시작 기능

Ext.define('Mail.profile.Tablet', {
   extend: 'Ext.app.Profile',

   config: {
      name: 'Tablet', views: ['tableView']
   },

   isActive: function() {
      return Ext.os.is('Tablet');
   }
   launch : function() {
      Ext.Msg.alert('profile's launch function');
   }
});

응용 프로그램의 시작 기능

Ext.application({
   name: 'Sencha', launch: function() {
      Ext.Msg.alert(Application's launch function);
   }
});

Sencha Touch에는 종속성을 선언하는 특정 방법이 있습니다. 하나는 애플리케이션 내에서 다른 하나는 클래스 내에서 선언합니다.

종속성을 정의하는 다양한 방법을 살펴 보겠습니다.

응용 프로그램 수준 종속성

여기에서 Ext.application을 만들 때 모든 종속성을 선언합니다.

Ext.application({
   name: 'MyApp',
   views: ['StudentsView'],
   models: ['StudentsModel'],
   controllers: ['StudentsController'],
   stores: ['StudentsStore'],
   profiles: ['Phone', 'Tablet']
});

이제 애플리케이션이로드되면 모든 종속성이 동시에로드됩니다. 다른 파일의 경로는-

  • MyApp.views.StudentsView
  • MyApp.models.StudentsModel
  • MyApp.stores.StudentsStore 등

위의 선언 방법은 파일을로드 할뿐만 아니라 활성 상태로 유지할 프로필도 결정합니다. 컨트롤러를로드 한 후 인스턴스화합니다. 상점이로드되면 인스턴스화하고 아직 제공되지 않은 경우 하나의 ID를 제공합니다.

프로필 별 종속성

응용 프로그램에서 프로필을 사용할 때 특정 프로필에만 필요한 기능이 거의 없을 수 있습니다.

프로필 특정 종속성은 응용 프로그램 수준 선언 대신 프로필 자체에서 선언됩니다.

Ext.define('MyApp.profile.Tablet', {
   extend: 'Ext.app.Profile', config: {
      views: ['StudentView'], controllers: ['StudentController'], models: ['StudentModel']
   }
});

프로파일이 활성화되었는지 여부에 관계없이 종속성이로드됩니다. 그러나 활성 프로필을 기반으로 컨트롤러 및 저장소 인스턴스화와 같은 추가 처리가 발생합니다.

중첩 된 종속성

더 큰 응용 프로그램이 있으면 여러 컨트롤러, 모델,보기 및 저장소가 있습니다.

더 큰 애플리케이션에서 모듈성을 유지하는 것은 항상 좋습니다. 이를 위해 하위 폴더를 정의 할 수 있으며 종속성을 선언하는 동안 하위 폴더 이름을 사용하여 선언 할 수 있습니다.

Ext.application({
   name: 'MyApp',
   controllers: ['Controller', 'nested.NewController'],
   views: ['class.Cview', 'SView']
});

위의 경우 다음 파일이로드됩니다.

  • MyApp.controllers.Controller
  • MyApp.controllers.nested.NewController
  • MyApp.Views.Sview
  • MyApp.Views.class.Cview

외부 종속성

클래스의 정규화 된 이름을 다음과 같이 지정하여 응용 프로그램 외부의 종속성을 지정할 수 있습니다.

Ext.Loader.setPath({
   'Class': 'Class'
});

Ext.application({
   views: ['Class.view.LoginForm', 'Welcome'],
   controllers: ['Class.controller.Sessions', 'Main'],
   models: ['Class.model.User']
});

위의 경우 다음 파일이로드됩니다.

  • Class/view/LoginForm.js
  • Class/controller/Sessions.js
  • Class/model/User.js
  • app/view/Welcome.js
  • app/controller/Main.js

사용중인 운영 체제, 작업중인 브라우저 및 환경에서 사용할 수있는 기능을 식별하는 데 도움이됩니다.

Sencha Touch는 환경에 특정한 정보를 얻기 위해 다양한 기능을 제공합니다. 조건이 if (Ext.os.is.Windows) {}이고 조건을 기반으로하면 아래에 언급 된 모든 방법을 체크인 할 수 있으며 작업을 수행 할 수 있습니다.

다음 메서드는 모두 부울 값을 반환합니다.

운영 체제

Ext.os는 우리가 작업중인 운영 체제를 알 수있는 다양한 방법을 제공하는 클래스입니다.

Sr. 아니요 방법 및 설명
1

Ext.os.is.webOS

이 함수는 webos 운영 체제를 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

2

Ext.os.is.RIMTable

이 함수는 RIMTable 운영 체제를 사용하는 경우 true를 리턴하고 그렇지 않으면 false를 리턴합니다.

Ext.os.is.Linux

이 함수는 Linux 운영 체제를 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

4

Ext.os.is.Windows

이 함수는 Windows 운영 체제를 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

5

Ext.os.is.MacOs

이 함수는 Mac 운영 체제를 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

6

Ext.os.is.BlackBerry

이 함수는 BlackBerry 운영 체제를 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

7

Ext.os.is.iOS

이 함수는 IOS 운영 체제를 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

8

Ext.os.is.Android

이 함수는 Android 운영 체제를 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

장치 감지

Sr. 아니요 방법 및 설명
1

Ext.os.is.iPad

이 함수는 iPad를 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

2

Ext.os.is.iPhone

이 함수는 iPhone을 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

Ext.os.is.iPod

이 함수는 iPod을 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

운영 체제 버전

Sr. 아니요 방법 및 설명
1

Ext.os.name

운영 체제의 이름을 반환합니다.

2

Ext.os.version.version

우리가 사용하는 운영 체제의 버전을 제공합니다.

브라우저 감지

Sr. 아니요 방법 및 설명
1

Ext.browser.is.IE

이 함수는 Internet Explorer 브라우저를 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

2

Ext.browser.is.FF

이 함수는 FireFox 브라우저를 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

Ext.browser.is.Chrome

이 함수는 Chrome 브라우저를 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

4

Ext.browser.is.Opera

이 함수는 Opera 브라우저를 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.
5

Ext.browser.is.Safari

이 함수는 Safari 브라우저를 사용하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

이 기능 Ext.browser는 다양한 다른 기능을 제공합니다-

Sr. 아니요 방법 및 설명
1

Ext.browser.userAgent

현재 userAgent를 반환합니다.

2

Ext.browser.isSecure

현재 페이지가 SSL을 사용하는 경우 true를 반환합니다.

Ext.browser.isStrict

브라우저가 엄격 모드이면 true를 반환합니다.

4

Ext.browser.engineName

브라우저 엔진 이름 (WebKit, Gecko, Presto, Trident 및 기타)을 반환합니다.

5

Ext.browser.engineVersion

브라우저 엔진의 버전을 반환합니다.

풍모

Ext.feature.has는 브라우저에 다음 기능이 있는지 확인하는 것입니다.

Sr. 아니요 방법 및 설명
1

Ext.feature.has.Audio

브라우저가 html5의 오디오 태그 기능을 지원하는 경우이 메서드는 true를 반환합니다.

2

Ext.feature.has.Canvas

브라우저가 html5의 캔버스 태그 기능을 지원하는 경우이 메서드는 true를 반환합니다.

Ext.feature.has.classList

브라우저가 html 요소에 대한 CSS 클래스를 추가, 제거 및 전환하는 데 사용되는 html5의 클래스 목록 기능을 지원하는 경우이 메서드는 true를 반환합니다.

4

Ext.feature.has.Css3dTransforms

브라우저가 css3의 Css 3d Transform 기능을 지원하는 경우이 메서드는 true를 반환합니다.

5

Ext.feature.has.CssAnimations

브라우저가 css3의 애니메이션을 지원하는 경우이 메서드는 true를 반환합니다.

6

Ext.feature.has.CssTransforms

브라우저가 css3의 Css 변환 기능을 지원하는 경우이 메서드는 true를 반환합니다.

7

Ext.feature.has.CssTransitions

브라우저가 css3의 전환 기능을 지원하는 경우이 메서드는 true를 반환합니다.

8

Ext.feature.has.DeviceMotion

브라우저가 장치 동작 기능을 지원하는 경우이 메서드는 true를 반환합니다.

9

Ext.feature.has.Geolocation

브라우저가 html5의 지리적 위치 기능을 지원하는 경우이 메서드는 true를 반환합니다.

10

Ext.feature.has.History

브라우저가 html의 히스토리 기능을 지원하는 경우이 메소드는 true를 리턴합니다.

11

Ext.feature.has.Orientation

브라우저가 장치 방향을 감지 할 수있는 경우이 메서드는 true를 반환합니다.

12

Ext.feature.has.OrientationChange

브라우저가 장치 방향의 변화를 감지 할 수있는 경우이 메서드는 true를 반환합니다.

13

Ext.feature.has.Range

범위는 범위 슬라이더 요소에 대한 HTML 입력 태그 유형이므로 브라우저가 슬라이더를 지원하는 경우이 함수는 true를 반환합니다.

14

Ext.feature.has.SqlDatabase

웹 SQL 데이터베이스는 쿼리 작업을 수행 할 수있는 데이터 n 데이터베이스를 저장하기위한 웹 페이지 API입니다. 브라우저가 웹 SQL 데이터베이스를 지원하는 경우이 메서드는 true를 반환합니다.

15

Ext.feature.has.Svg

Svg는 Scalable Vector Graphics의 약자이며 브라우저가 html 5의 svg 기능을 지원하는 경우 true를 반환합니다.

16

Ext.feature.has.Touch

이 메서드는 브라우저에 터치 기능이있는 경우 true를 반환합니다.

17

Ext.feature.has.Video

브라우저가 html 5 비디오 태그를 지원하는 경우이 메서드는 true를 반환합니다.

18

Ext.feature.has.Vml

Vml은 xml 기반 마크 업 언어 인 벡터 마크 업 언어를 나타냅니다. 따라서 브라우저가 vml을 지원하는 경우이 메서드는 true를 반환합니다.

19

Ext.feature.has.WebSockets

웹 소켓은 기본적으로 클라이언트와 서버 간의 두 가지 통신을 지원하는 컴퓨터 용 통신 프로토콜입니다. 이 메서드는 브라우저가 WebSocket을 지원하는 경우 true를 반환하고 그렇지 않으면 false를 반환합니다.

이벤트는 클래스에 어떤 일이 발생할 때 시작되는 것입니다. 예를 들어, 버튼이 클릭 될 때 또는 요소가 렌더링되기 전 / 후입니다.

이벤트 작성 방법

다음은 이벤트 작성 방법입니다.

  • 리스너를 사용하는 내장 이벤트.
  • 나중에 이벤트 첨부
  • 맞춤 이벤트

리스너를 사용하는 내장 이벤트

Sencha Touch는 Sencha Touch 파일에서 이벤트 및 사용자 정의 이벤트를 작성하기위한 리스너 속성을 제공합니다.

Sencha Touch에서 청취자 작성

다음과 같이 패널에 listen 속성을 추가하여 이전 프로그램 자체에 리스너를 추가합니다.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.application({
            name: 'Sencha', launch: function() {
               Ext.create('Ext.Panel', {
                  html: 'My Panel', fullscreen: true, listeners: {
                     painted: function() {
                        Ext.Msg.alert('I was painted to the screen');
                     }
                  }
               });
            }
         });
      </script> 
   </head>
</html>

이것은 다음 결과를 생성합니다-

이렇게하면 listeners 속성에 여러 이벤트를 작성할 수도 있습니다.

동일한 리스너의 여러 이벤트

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">   
         Ext.application({
            name: 'Sencha',
            launch: function() {
               var myButton = Ext.Viewport.add({
                  xtype: 'button',
                  centered: true,
                  text: 'Click me'
               });

               myButton.on({
                  tap: function() {
                     var randomWidth = 100 + Math.round(Math.random() * 200);
                     this.setWidth(randomWidth);
                  },
                  widthchange: function(button, newWidth, oldWidth) {
                     alert('My width changed from ' + oldWidth + ' to ' + newWidth);
                  }
               });
            }
         });       
      </script> 
   </head>
</html>

다음 결과가 생성됩니다-

나중에 이벤트 첨부

이전 이벤트 작성 방법에서는 요소를 생성 할 때 리스너에 이벤트를 작성했습니다.

이벤트를 첨부하는 다른 방법은 다음과 같습니다.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.application({
            name: 'Sencha',
            launch: function() {
               var myButton = Ext.Viewport.add({
                  xtype: 'button',
                  centered: true,
                  text: 'Click me'
               });
               
               myButton.on('tap', function() {
                  alert("Event listener attached by .on");
               });
            }
         });
      </script> 
   </head>
</html>

다음 결과가 생성됩니다-

맞춤 이벤트

Sencha Touch에서 커스텀 이벤트를 작성하고 fireEvent 메소드로 이벤트를 실행할 수 있습니다. 다음 예에서는 맞춤 이벤트를 작성하는 방법을 설명합니다.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.application({
            name: 'Sencha',
            launch: function() {
               var myButton = Ext.Viewport.add({
                  xtype: 'button',
                  centered: true,
                  text: "Just wait 5 seconds",

                  listeners: {
                     myEvent: function(button, points) {
                        alert('myEvent was fired! You score ' + points + ' points');
                     }
                  }
               });

               Ext.defer(function() {
                  var number = Math.ceil(Math.random() * 100);
                  myButton.fireEvent('myEvent', myButton, number);
               }, 5000);
            }
         });
      </script> 
   </head>
</html>

페이지가로드되고 문서가 준비되면 버튼이있는 UI 페이지가 나타나고 5 초 후에 이벤트가 발생하므로 문서가 준비되면 5 초 후에 경고 상자가 나타납니다.

여기에서 맞춤 이벤트 'myEvent'를 작성했으며 이벤트를 button.fireEvent (eventName);

레이아웃은 요소가 컨테이너에 배열되는 방식입니다. 수평, 수직 또는 기타가 될 수 있습니다. Sencha Touch는 항상 사용자 정의 레이아웃을 작성할 수 있지만 라이브러리에 다른 레이아웃이 정의되어 있습니다.

Sr. 아니. 레이아웃 및 설명
1 hBox

이 레이아웃을 사용하면 요소를 가로로 배포 할 수 있습니다.

2 vBox

이 레이아웃을 사용하면 요소를 세로로 배포 할 수 있습니다. 이것은 일반적으로 사용되는 레이아웃 중 하나입니다.

적당한

이 레이아웃에서 컨테이너는 단일 패널로 채워지고 레이아웃과 관련된 특정 요구 사항이없는 경우이 레이아웃이 사용됩니다.

4 카드 (TabPanel)

이 레이아웃은 탭 방식으로 다양한 구성 요소를 정렬합니다. 컨테이너 상단에 탭이 표시됩니다. 하나의 탭만 표시되고 각 탭은 다른 구성 요소로 간주됩니다.

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을 공유 할 수 있습니다.

Sencha Touch는 Ajax 및 Ajax2 개발 작업을위한 XHR2 구성을 제공합니다.

XHR2는 서버에서 데이터를 요청하는 데 사용되는 xmlHttpRequest 레벨 2입니다. 모든 웹 애플리케이션의 경우 데이터는 서버에 있으며 페이지가로드되면 Ajax 요청을 사용하여 서버에서 데이터에 액세스해야합니다.

Sencha Touch의 XHR2는 특정 요청에 대해 전송 된 데이터의 양을 사용자에게 보여주는 진행 표시 줄 기능을 제공합니다. XHR2가 새로 추가되었으므로 브라우저에서 지원하는지 확인해야합니다.

다음은 브라우저가 XHR2를 지원하는지 확인하는 기능입니다.

if (Ext.feature.has.XHR2) {
   // Here we can write functionality to work if browser supports XHR2 
}

XHR2를 통한 점진적 업로드가 브라우저에서 지원되는지 여부도 확인할 수 있습니다.

if (Ext.feature.has.XHRUploadProgress) {
   // Here we can write functionality to work if browser supports progressive uploads
}

Sencha Touch에는 다양한 새로운 XHR2 기능이 포함되어 있습니다.

Sr. 아니요 특징 및 설명
1

XHR2: true

이것은 응용 프로그램에서 XHR2 기능을 활성화 및 비활성화하는 데 사용됩니다.

2

Ext.field.File

필드 유형에 대해 더 많은 정보를 제공하기 위해 새 파일 필드가 추가되었습니다.

Ext.field.FileInput

이것은 FileInput을 제공합니다.

4

Ext.progressIndicator

이는 진행률 표시 줄로 전송 된 데이터의 정확한 비율을 제공하기위한 것입니다.

5

xtype: fileinput

fileInput 클래스의 인스턴스를 만듭니다.

6

xtype: filefield

파일 클래스의 인스턴스를 생성합니다.

7

responseType : value

이 매개 변수는 텍스트, 문서, blob 등과 같은 다양한 유형의 응답을 허용합니다.

다음은 매개 변수가 있거나없는 간단한 ajax 요청을 보내고 ajax를 사용하여 파일을 업로드하는 예입니다.

매개 변수가없는 간단한 Ajax 요청-성공

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.setup({
            requires: [ 'Ext.Panel', 'Ext.Button', 'Ext.form.Panel'], onReady: function() {
               var request = {
                  url: 'https://www.tutorialspoint.com/sencha_touch/index.htm',
                  method: 'POST',
                  xhr2: true,
                  success: function(response) {
                     Ext.Msg.alert('Ajax call successful');
                  },
                  failure: function(response) {
                     Ext.Msg.alert('Ajax call failed');
                  }
               };
               Ext.Viewport.add({
                  xtype:"panel",
                  layout:"vbox",
                  fullscreen:true,
                  items: [
                     {
                        xtype:"button",
                        text: "Ajax",
                        ui: 'confirm',
                        handler: function(){
                           Ext.Ajax.request(request);
                        }
                     }
                  ]
               });
            }
         });
      </script>
   </head>
   <body>
   </body>
</html>

다음 결과가 생성됩니다-

위의 예는 언급 된 URL이 올 바르기 때문에 성공한 ajax 호출을 보여줍니다. 이 예에서는 매개 변수를 전달하지 않고 언급 된 URL에 도달하는 단순한 ajax 요청 일뿐입니다.

개발자 도구에서 크롬 브라우저를 사용하는 경우 네트워크 섹션으로 이동하면 전송중인 요청과 수신 된 응답을 볼 수 있습니다.

매개 변수가없는 간단한 Ajax 요청-실패

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.setup({
            requires: [
               'Ext.Panel',
               'Ext.Button',
               'Ext.form.Panel'
            ],
            onReady: function() {
               var request = {
                  url: 'https://www.tutorialspoint.com/sencha_touch/indexx.htm',
                  method: 'POST',
                  xhr2: true,
                  success: function(response) {
                     Ext.Msg.alert('Ajax call successful');
                  },
                  failure: function(response) {
                     Ext.Msg.alert('Ajax call failed');
                  }
               };
               Ext.Viewport.add({
                  xtype:"panel",
                  layout:"vbox",
                  fullscreen:true,
                  items: [
                     {
                        xtype:"button",
                        text: "Ajax",
                        ui: 'confirm',
                        handler: function(){
                           Ext.Ajax.request(request);
                        }
                     }
                  ]
               });
            }
         });
      </script>
   </head>
   <body>
   </body>
</html>

다음 결과가 생성됩니다-

위의 예에서는 ajax 실패가 어떻게 작동하는지 보여주기 위해 잘못된 URL을 언급했습니다. 이 예제와 이전 예제를 비교하면 차이점을 찾을 수 있습니다.

Ajax 요청에서 매개 변수 보내기

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.setup({
            requires: [
               'Ext.Panel',
               'Ext.Button',
               'Ext.form.Panel'
            ],

            onReady: function() {
               var formData = new FormData();
               formData.append("firstName", "Hi");
               formData.append("lastName", "Reader");

               // Request will be sent as part of the payload instead of standard post data
               var request = {
                  url: 'https://www.tutorialspoint.com/sencha_touch/sencha_json.php',
                  method: 'POST',
                  xhr2: true,
                  data: formData,
                  success: function(response) {
                     var out = Ext.getCmp("output");
                     response = Ext.JSON.decode(response.responseText, true);
                     Ext.Msg.alert(response.message);
                  },
                  failure: function(response) {
                     var out = Ext.getCmp("output");
                     Ext.Msg.alert('Ajax failed!');
                  }
               };

               Ext.Viewport.add({
                  xtype:"panel",
                  layout:"vbox",
                  fullscreen:true,
                  items: [
                     {
                        xtype:"button",
                        text: "Ajax",
                        ui: 'confirm',
                        handler: function(){
                           Ext.Ajax.request(request);
                        }
                     }
                  ]
               });
            }
         });      
      </script>
   </head>
   <body>
   </body>
</html>

다음 결과가 생성됩니다-

이 예제에서는 ajax 호출의 data 속성을 사용하여 ajax와 함께 매개 변수를 전달합니다.

Ajax를 사용하여 파일 업로드

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.setup({
            requires: [
               'Ext.Panel',
               'Ext.MessageBox',
               'Ext.Button',
               'Ext.ProgressIndicator',
               'Ext.form.Panel',
               'Ext.field.FileInput'
            ],

            onReady: function() {
               var progressIndicator = Ext.create("Ext.ProgressIndicator", {
                  loadingText: "Uploading: {percent}%"
               });

               var request = {
                  url: 'https://www.tutorialspoint.com/sencha_touch/sencha_json.php',
                  method: 'POST',
                  xhr2: true,
                  progress:progressIndicator,
                  success: function(response) {
                     Ext.Msg.alert('File uploaded successfully.');
                  },
                  failure: function(response) {
                     Ext.Msg.alert('File upload failed.');
                  }
               };

               Ext.Viewport.add(progressIndicator);
               Ext.Viewport.add({
                  xtype:"panel",
                  layout:"vbox",
                  fullscreen:true,
                  items: [
                     {
                        xtype:"fileinput",
                        accept:"image/jpeg"
                     },
                     {
                        xtype:"button",
                        text: "Upload",
                        ui: 'confirm',
                        handler: function(){
                           var input = Ext.Viewport.down("fileinput").input;
                           var files = input.dom.files;
                           if (files.length) {
                              request.binaryData = files[0];
                              Ext.Ajax.request(request);
                           }else {
                              Ext.Msg.alert("Please Select a JPG");
                           }
                        }
                     }
                  ]
               });
            }
         });
      </script>
   </head>
   <body>
   </body>
</html>

다음 결과가 생성됩니다-

이 예제는 ajax 호출을 사용하여 데이터를 업로드하는 방법을 보여줍니다. 이 예에서는 진행률 표시 줄 표시기를 사용하여 파일을 업로드하는 동안 진행률을 표시합니다.

Sencha Touch는 요구 사항에 따라 사용자 정의 할 수있는 다양한 UI 구성 요소를 제공합니다.

Sr.N0. 구성 요소 및 설명
1 캐 러셀

이 UI 구성 요소는 캐 러셀을 표시하는 데 사용됩니다.

2 명부

이 UI 구성 요소는 목록을 표시하는 데 사용됩니다.

중첩 목록

이 UI 구성 요소는 중첩 된 목록을 표시하는 데 사용됩니다.

4 형태

이 UI 구성 요소는 양식을 표시하는 데 사용됩니다.

5 차트

이 UI 구성 요소는 다양한 유형의 차트를 표시하는 데 사용됩니다.

6 부동 구성 요소

이 UI 구성 요소는 플로팅 구성 요소를 표시하는 데 사용됩니다.

7 탭 패널

이 UI 구성 요소는 탭 패널보기를 표시하는 데 사용됩니다.

8 탐색보기

이 UI 구성 요소는 탐색보기를 표시하는 데 사용됩니다.

9 액션 메뉴

이 UI 구성 요소는 작업 메뉴 표시 줄을 표시하는 데 사용됩니다.

10 데이터보기

이 UI 구성 요소는 데이터보기를 표시하는 데 사용됩니다.

11 지도

이 UI 구성 요소는 Google지도를 표시하는 데 사용됩니다.

Sencha Touch에는 기본 패키징 기능이 있습니다.

다음은 Sencha Touch의 기본 패키징 개념에 대한 링크입니다.

Sr. 아니. 개념 및 설명 링크
1 기본 iOS 프로비저닝
2 네이티브 API

기본 JavaScript 모범 사례

모든 JavaScript 관련 코드를 별도의 파일에 보관하는 것이 좋습니다. js (external JS) 파일을 작성하는 대신 <script> 헤드 섹션 아래의 태그 또는 문서 본문의 인라인 자바 스크립트.

요소가 추가 논리에서 사용되기 전에 항상 null 검사를 수행하십시오.

다른 프로그래머가 코드를 쉽게 이해할 수 있도록 항상 명명 규칙을 따르십시오.

코드를 쉽게 이해할 수 있도록하려면 함수가 수행하는 작업 뒤에 명확한 논리를 사용하여 JS 메서드에 대한 주석을 작성하는 것이 항상 선호됩니다.

Sencha Touch에 특화된 모범 사례

Sencha Touch 권장 폴더 구조를 사용하면 JS 압축 또는 축소시 도움이됩니다.

html 페이지 자체에 쓰는 대신 컨트롤러에서 리스너 (onclick / onblur 등)를 사용하는 것이 좋습니다.

보기에서 상점을 호출 할 때 상점 인스턴스를 작성하지 마십시오.

스토어의 인스턴스를 생성 할 때 성능에 영향을 미치므로 항상 삭제해야합니다.

Sencha Touch를 사용하는 동안 다른 간단한 JavaScript 파일을 지정하지 마십시오. Ext 클래스의 모든 기능을 사용하십시오 (컨트롤러 또는 유틸리티에 언급 됨).

모델 매핑과 이름이 같으면 매핑을 지정하지 마십시오. 이름 만이 목적을 해결할 것입니다.

보기에서 불필요한 속성을 사용하지 마십시오. 필수 속성과 기본값과 다른 값만 사용하세요.