Memutakhirkan aplikasi perusahaan ke Angular 16

May 07 2023
Ini dia rasa sakitnya
Saya benar-benar dibeli oleh semua fitur Angular v16 baru, dimulai dengan sinyal, dan yang lainnya. Dan saya tidak dapat menahan keinginan untuk memutakhirkan salah satu aplikasi perusahaan hanya untuk melihat betapa sulitnya hal itu.
Rilis sudut 16 — ngcc tidak lebih

Saya benar-benar dibeli oleh semua fitur baru Angular v16 , dimulai dengan signal , dan yang lainnya. Dan saya tidak dapat menahan keinginan untuk memutakhirkan salah satu aplikasi perusahaan hanya untuk melihat betapa sulitnya hal itu.

Ada ujung tombak dan ujung berdarah. Anda dapat memilih untuk memimpin atau berdarah, itu pilihan rasa sakit Anda.

Semua orang ( hampir ) berbicara tentang Angular 16. Hype atau tidak, kemungkinan besar Anda sudah membaca tentang:

  • reaktivitas granular (sinyal)
  • diperlukan @Inputs()
  • kueri, data, dan parameter penyelesai sebagai Inputs()
  • langganan yang dapat dihancurkan
  • masukan pada ngComponentOutlets
  • Vite untuk server pengembangan
  • Hidrasi SSR
  • sinyal, sinyal, sinyal…

Di mana tangkapan untuk aplikasi perusahaan yang ada?

Hanya Ivy yang didukung.

Dan rasa sakitnya?

Pustaka lama…

Siapa yang harus disalahkan?

Astaga ! pertanyaan sulit. Tapi itu adalah campuran tanggung jawab.

  1. Pengembang perpustakaan sudut . Hanya untuk menyebutkan beberapa perpustakaan: custom-validators , text-mask, versi lama for forly , ng-bootstrap , nebular (lebih lanjut tentang versi lama segera). Tidak ada yang ditingkatkan dengan benar untuk menggunakan versi Angular terbaru atau setidaknya didukung. Beberapa jelas ditinggalkan. Ivy tidak didukung.
  2. Pengembang perusahaan . Oke, saya tahu tidak mudah untuk selalu memperbarui semua dependensi Anda, lebih sulit dicapai jika " kode sudah berfungsi, tidak perlu memperbarui ". Sudah mengalami rasa sakit ini saat memperbarui ke Angular 15; beberapa komponen Angular Material yang berat dan dikustomisasi dengan buruk masih membuat kebisingan dalam kode kami (tidak tahu berapa lama modul akanLegacyMaterialXXXbertahan).
  3. Tim sudut ( ?) Kami dapat memperdebatkan yang satu ini, tetapi pada MHO pertanyaannya adalah “ apakah Angular 16 dimaksudkan untuk memutakhirkan aplikasi perusahaan yang ada atau hanya untuk membuat aplikasi baru dari nol? ”.
    Komentar ini tidak cantik ( dari masalah: Cara alternatif untuk mengkompilasi pustaka non-ivy setelah menghapus ngcc di v16 #24797) :
  4. https://github.com/angular/angular-cli/issues/24797#issuecomment-1449481158

Maksud saya, basis kode yang sangat besar, yang menyeret beberapa (banyak) komponen " sudah berfungsi seperti ini " yang bergantung pada pustaka yang ditinggalkan, tidak mudah untuk ditingkatkan. Itu juga bisa berarti proyek yang sama sekali baru (waktu pengembang), dan untuk apa? jadi sudut ≤ 17 merusak semuanya lagi? keputusan sulit. “ Mungkin kita seharusnya tetap menggunakan Angular 9…

Gambar dari https://cilected.com/bootstrap-4-vs-bootstrap-5/

Jika ada yang kesulitan dengan pemutakhiran Bootstrap (bukan ng-bootstrap ) versi 4 hingga 5, Anda dapat memiliki sedikit gagasan, sebagian besar masih berfungsi dan terlihat hampir (hampir) sama, tetapi pada saat yang sama, banyak hal yang dulu berfungsi ( atau terlihat bagus pada standar Bootstrap) berakhir rusak.

Bayangkan basis kode yang sangat bergantung pada gaya Bootstrap lama, komponen Bahan Angular yang disesuaikan dan dikembangkan dengan buruk, banyak arahan dan pustaka yang tidak dipelihara untuk ditangani dari animasi hingga validasi formulir.
Memutakhirkan ke versi kerangka apa pun yang mempromosikan cara yang lebih baik untuk ehm…, semuanya (?) tidak akan menjadi tugas yang mudah.

Versi lama, kenapa?

Saat Anda mengerjakan proyek, Anda mungkin menghadapi keputusan berikut:

Apakah kita harus menggunakan framework UI? atau apakah kita tetap menggunakan komponen ad-hok berkode tangan yang ditata menggunakan CSS biasa?

Pilih racun Anda:

  • Bahan
  • Bootstrap
  • Nebula
  • Angin penarik
  • sebut saja, kami memiliki pilihan yang tak terbatas

Peningkatan rasa sakit tidak dapat dihindari.

Saya bersikeras pada upaya saya untuk meningkatkan. Seberapa sulitkah itu?
Jadi hanya untuk mendapatkan aplikasi yang berjalan tanpa kesalahan kompilasi (mengabaikan kerusakan visual), saya memperbarui sebagian besar pustaka yang dapat diperbarui. Mencoba lagi, dan lagi, dan lagi… bilas dan ulangi…

Masalah utama adalah bahwa Anda dapat memiliki banyak perpustakaan usang, terbengkalai, atau tidak terpelihara di mana kode dasar yang berfungsi, MASIH BEKERJA! Satu-satunya masalah adalah ketergantungan Angular n perpustakaan ini sudah usang.

Untuk misalnya. salah satu perpustakaan semacam ini dalam proyek yang saya kerjakan adalah text-mask , sebuah perpustakaan dari 5 tahun yang lalu. Dan meskipun ini adalah perpustakaan yang tidak terawat, kodenya tetap berfungsi. Bermigrasi ke perpustakaan lain akan membutuhkan waktu + waktu pengembang untuk menguji semuanya masih berfungsi seperti sebelumnya.
Menyalin dan menempelkan kode perpustakaan utama seolah-olah itu adalah perpustakaan internal dalam proyek, membuat beberapa penyesuaian, dan voila , masih berfungsi, kodenya tidak salah, dependensi perpustakaan " salah ". Namun demikian, jika menggunakan pustaka asli, Angular 16 menampilkan kesalahan, “ Perpustakaan tidak mendukung Ivy ”.

Sejauh ini, ada begitu banyak dependensi lama, usang, tidak terawat, dan terbengkalai dalam proyek ini sehingga pemutakhiran dapat menjadi proyek yang sama sekali berbeda dengan sendirinya. Berhenti mencoba memutakhirkan setelah menyadari bahwa ada banyak perubahan yang harus dilakukan hanya untuk mendapatkan bangunan yang bersih.

Apakah mungkin untuk memutakhirkan aplikasi Angular perusahaan ke Angular 16?

Itu mungkin, tetapi jika aplikasinya rumit, atau jika memiliki banyak, katakanlah " belum didukung oleh perpustakaan Angular 16 " mungkin tidak sesederhana itu.

Bersiaplah untuk memulai dengan melakukan banyak pengujian kompilasi untuk menentukan pustaka mana yang memerlukan peningkatan versi, dan mana yang mungkin memerlukan perlakuan khusus (seperti mengekstrak kode yang berfungsi dan membuat versi internal untuk pustaka tersebut).

Kemudian, jika Anda berhasil mendapatkan build yang bersih, Anda mungkin perlu memeriksa semua gaya visual untuk setiap komponen (untuk berjaga-jaga jika ada sesuatu yang rusak secara visual).

Upgrade masuk akal (lebih dari mungkin), tapi itu tidak akan menjadi " kemenangan sempurna ".

Saya benar-benar berhasil memutakhirkan aplikasi Angular ke Angular 16.
Ini bukan aplikasi perusahaan, tidak memiliki ketergantungan eksternal selain Tailwind dan Angular itu sendiri, jadi sangat sederhana sehingga pemutakhiran hampir merupakan tugas langsung.

Pada aplikasi perusahaan nyata, jangan mengharapkan jalan yang bahagia, atau akhir yang bahagia. Gagal dalam tugas ini memiliki peluang tinggi untuk terjadi.

Dan bukan karena saya tidak menyukai Angular 16, saya sangat menyukai semua fitur yang diumumkan, tetapi memutakhirkan ke versi yang baru dirilis ini AKAN MENYENANGKAN!

Pengadopsi awal : Waspadalah!