EmberJS - Mengelola Dependensi

Ember menggunakan NPM dan Bower untuk mengelola dependensi yang ditentukan dalam package.json untuk NPM dan bower.json untuk Bower. Misalnya, Anda mungkin perlu menginstal SASS untuk lembar gaya Anda yang tidak diinstal oleh Ember saat mengembangkan aplikasi Ember. Untuk melakukannya, gunakan Ember Addons untuk berbagi perpustakaan yang dapat digunakan kembali. Jika Anda ingin menginstal kerangka kerja CSS atau dependensi pemilih data JavaScript, gunakan pengelola paket Bower.

Addons

The Ember CLI dapat digunakan untuk menginstal Ember Addons dengan menggunakan perintah berikut -

ember install ember-cli-sass

Perintah ember install akan menyimpan semua dependensi ke file konfigurasi masing-masing.

Punjung

Ini adalah pengelola paket untuk web yang mengelola komponen HTML, CSS, JavaScript, atau file gambar. Ini pada dasarnya memelihara dan memantau semua paket dan memeriksa pembaruan baru. Ini menggunakan file konfigurasi bower.json untuk melacak aplikasi yang ditempatkan di root proyek Ember CLI.

Anda dapat menginstal dependensi proyek dengan menggunakan perintah berikut -

bower install <dependencies> --save

Aktiva

Anda dapat menempatkan JavaScript pihak ketiga di vendor / folder proyek Anda yang tidak tersedia sebagai paket Addon atau Bower dan menempatkan aset sendiri seperti robots.txt, favicon, dll. Di folder / publik proyek Anda. Dependensi yang tidak diinstal oleh Ember saat mengembangkan aplikasi Ember, harus disertakan dengan menggunakan file manifes ember-cli-build.js .

Modul JavaScript AMD

Anda dapat memberikan jalur aset sebagai argumen pertama dan daftar modul dan ekspor sebagai argumen kedua. Anda dapat menyertakan aset ini dalam file manifes ember-cli-build.js sebagai -

app.import('bower_components/ic-ajax/dist/named-amd/main.js', {
   exports: {
      'ic-ajax': [
         'default',
         'defineFixture',
         'lookupFixture',
         'raw',
         'request'
      ]
   }
});

Aset Khusus Lingkungan

Aset yang berbeda dapat digunakan di lingkungan yang berbeda dengan mendefinisikan objek sebagai parameter pertama yang merupakan nama lingkungan dan nilai suatu objek harus digunakan sebagai aset di lingkungan tersebut. Dalam file manifes ember-cli-build.js , Anda dapat menyertakan sebagai -

app.import ({
   development: 'bower_components/ember/ember.js',
   production:  'bower_components/ember/ember.prod.js'
});

Aset Lainnya

Setelah semua aset ditempatkan di folder / publik , mereka akan disalin ke direktori dist /. Misalnya, jika Anda menyalin favicon yang ditempatkan di folder public / images / favicon.ico , ini akan disalin ke direktori dist / images / favicon.ico . Aset pihak ketiga dapat ditambahkan secara manual di vendor / folder atau dengan menggunakan manajer paket Bower melalui opsi import () . Aset yang tidak ditambahkan dengan menggunakan opsi import () , tidak akan ada di build akhir.

Misalnya, perhatikan baris kode berikut yang mengimpor aset ke dalam folder dist / .

app.import('bower_components/font-awesome/fonts/fontawesome-webfont.ttf');

Baris kode di atas membuat file font di dist / font-awesome / font / fontawesomewebfont.ttf . Anda juga dapat menempatkan file di atas di jalur yang berbeda seperti yang ditunjukkan di bawah ini -

app.import('bower_components/font-awesome/fonts/fontawesome-webfont.ttf', {
   destDir: 'assets'
});

Ini akan menyalin file font di dist / assets / fontawesome-webfont.ttf .