Sencha Touch - Ketergantungan

Ada beberapa cara tertentu yang didefinisikan di Sencha Touch untuk mendeklarasikan dependensi, satu di dalam aplikasi dan yang lainnya di dalam kelas.

Mari kita lihat berbagai cara untuk mendefinisikan dependensi.

Ketergantungan Tingkat Aplikasi

Di sini, kami mendeklarasikan semua dependensi saat kami membuat Ext.application.

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

Sekarang, saat aplikasi dimuat, semua dependensi akan dimuat pada saat yang bersamaan. Jalur file lain akan -

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

Cara deklarasi di atas tidak hanya memuat file, tetapi juga memutuskan profil mana yang harus tetap aktif. Setelah memuat pengontrol, itu memastikan untuk memberi contoh. Setelah penyimpanan dimuat, itu membuat instance dan memberikan satu id jika belum diberikan.

Dependensi khusus profil

Saat kami menggunakan profil dalam suatu aplikasi, mungkin ada kemungkinan bahwa beberapa fungsi hanya diperlukan untuk beberapa profil tertentu.

Dependensi khusus profil dideklarasikan di profil itu sendiri, bukan di deklarasi level aplikasi.

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

Dependensi dimuat terlepas dari profil yang aktif atau tidak. Namun, berdasarkan profil aktif, pemrosesan lebih lanjut seperti instantiating controller dan penyimpanan terjadi.

Dependensi Bersarang

Ketika kami memiliki aplikasi yang lebih besar, kami memiliki banyak pengontrol, model, tampilan, dan penyimpanan.

Itu selalu baik untuk menjaga modularitas dalam aplikasi yang lebih besar. Untuk itu, kita bisa mendefinisikan subfolder dan saat mendeklarasikan dependensi kita bisa menggunakan nama subfolder untuk mendeklarasikannya.

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

Dalam kasus di atas, file berikut akan dimuat -

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

Dependensi Eksternal

Kita dapat menentukan dependensi di luar aplikasi dengan memberikan nama kelas yang memenuhi syarat sebagai -

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

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

Dalam kasus di atas, file berikut akan dimuat -

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