React Native vs. Android: Perbandingan Komprehensif

May 06 2023
Perjalanan Saya dari Android ke React Native
Sebagai developer Android dengan pengalaman lebih dari 7 tahun, saya selalu tertarik dengan dunia Java dan Kotlin. Namun sekitar setahun yang lalu, saya mendapati diri saya ingin menjelajahi sesuatu yang baru — dan saat itulah saya mulai mendalami React Native.

Sebagai developer Android dengan pengalaman lebih dari 7 tahun, saya selalu tertarik dengan dunia Java dan Kotlin. Namun sekitar setahun yang lalu, saya mendapati diri saya ingin menjelajahi sesuatu yang baru — dan saat itulah saya mulai mendalami React Native.

Saya awalnya tertarik pada React Native karena kecintaan saya pada JavaScript dan keingintahuan saya tentang pengembangan lintas platform. Plus, saya tahu bahwa mempelajari RN hanya akan membuat saya lebih berharga di industri teknologi.

Sekarang, setelah berbulan-bulan bekerja dengan RN, saya ingin berbagi pengalaman saya dengan orang lain yang mungkin sedang mempertimbangkan jalan ini. Saya telah belajar banyak selama ini, dan saya percaya bahwa wawasan saya dapat membantu orang lain memilih arah yang tepat untuk diikuti dan menghindari membuang-buang waktu pada rute yang salah.

Saya baru-baru ini menulis ulang proyek Kotlin saya di React Native dan Anda dapat melihat kodenya dihttps://github.com/thesiamak/sendit-react-native. Proyek Kotlin asli juga tersedia dihttps://github.com/thesiamak/sendit. Jangan ragu untuk memeriksanya dan membandingkan kinerja, kode, dan perbedaan aplikasi.

Tentu saja, pemahaman saya tentang React Native terbatas pada pengalaman saya — tetapi saya selalu ingin belajar dan berdiskusi dengan orang lain. Jadi, jangan ragu untuk berkomentar dan membagikan pemikiran Anda, dan mari terus tumbuh bersama.

Arsitektur

Dalam hal arsitektur, React Native beroperasi secara berbeda dari apa yang biasa dilakukan pengembang Android. Tidak seperti Android, React Native tidak memiliki pedoman arsitektur yang ketat. Faktanya, arsitektur di React Native terutama didasarkan pada bagaimana komponen Anda saling bergantung satu sama lain.

Sebagai pengembang, Anda memiliki fleksibilitas untuk mendesain kode sumber Anda untuk mengikuti pola arsitektur apa pun. Namun, tanpa pedoman atau opini resmi, mudah untuk merasa tersesat dan tidak tahu harus mulai dari mana. Di sisi lain, kesederhanaan ini memudahkan pengembang baru untuk mempelajari dasar-dasar React Native — cara kerjanya, apa itu komponen, apa itu Redux, dan bagaimana menggunakan semua alat ini untuk memecahkan masalah.

Namun seiring berkembangnya proyek Anda, mengelola basis kode dapat dengan cepat menjadi kewalahan. Tanpa arsitektur yang ditentukan, sangat mudah untuk membuat kekacauan dan sulit untuk men-debug masalah. Akibatnya, pengembang berpengalaman merekomendasikan untuk memperkenalkan struktur dan organisasi ke dalam proyek sejak dini untuk menghindari sakit kepala di kemudian hari.

Flux adalah pola arsitektur searah yang memiliki satu sumber kebenaran untuk data. Itu tidak memiliki pemisahan yang jelas antara tampilan dan logika bisnis. Di sisi lain, MVVM memiliki pemisahan perhatian yang jelas antara tampilan, model tampilan, dan model, dengan pengikatan data dua arah.

Bereaksi Asli, tidak seperti pengembangan aplikasi asli tradisional, tidak memiliki arsitektur atau struktur yang ditentukan. Alih-alih, ia menyerahkan kepada pengembang untuk menentukan cara terbaik menyusun komponen aplikasi dan aliran data. Beberapa pola umum yang digunakan developer di React Native antara lain Flux (mirip dengan MVVM dengan aliran data searah), Redux , dan model yang berpusat pada komponen .

Pengembangan lingkungan

Dalam hal lingkungan pengembangan, React Native menawarkan berbagai IDE untuk dipilih, tetapi menurut saya VS Code adalah yang paling efisien dan kaya fitur. Berasal dari dunia Android, saya sangat terkejut saat mengetahui betapa ringan, sederhana, dan fleksibelnya VS Code dibandingkan dengan Android Studio (Ambil kehausan sumber daya di Android Studio sebagai contoh).

Dengan fitur hot-reloading yang disediakan oleh mesin JS Hermes yang dioptimalkan di atas Metro bundler , saya terus mengembangkan kode React Native tanpa perlu membangun ulang aplikasi, meskipun terkadang ada crash. Di sisi Native Android, tim Developer Relations telah bekerja selama bertahun-tahun untuk menghadirkan fitur serupa seperti instant run (yang sekarang sudah mati!) atau Live Edit untuk sistem Compose UI , tetapi masih dalam proses sementara hanya untuk Bagian UI sementara Metro bekerja dengan sempurna untuk apa pun kecuali beberapa kode atau izin asli.

Fitur hebat lainnya dari React Native adalah mode Expo , yang menangani banyak tugas membosankan bagi pengembang yang mungkin tidak memiliki pengalaman yang diperlukan untuk menanganinya. Ini sangat membantu bagi pengembang baru yang baru memulai dengan framework. Expo menangani hal-hal seperti izin , penyiapan aplikasi , dan banyak fitur bermanfaat lainnya. Namun, perlu dicatat bahwa sebagian besar pustaka asli BELUM kompatibel dengan mode Expo. Meskipun demikian, ini bisa menjadi alat yang hebat untuk memulai React Native dan memicu minat dalam pemrograman sejak awal.

Di React Native, pengembang dapat membuat proyek Android dan iOS satu per satu di luar mode Expo. Hal ini memungkinkan ekstensi khusus platform , seperti mengembangkan kode asli dan berkomunikasi dengan jembatan JS , atau memanfaatkan threading , broadcasting , dan intents . Fleksibilitas ini memungkinkan pengembang mengoptimalkan kinerja dan menyempurnakan perilaku aplikasi untuk setiap platform. Namun, itu juga membutuhkan pemahaman yang lebih dalam tentang platform asli dan alat pengembangan terkait.

Penggunaan Ulang Kode

Aplikasi React Native terdiri dari banyak komponen pre-built atau kustom yang berfungsi sebagai wadah kode yang dapat dipanggil dari mana saja dalam kode sumber. Konsep kode yang dapat digunakan kembali ini lebih mudah digunakan dan dipelihara dibandingkan dengan komponen berbasis kelas yang digunakan dalam ekosistem Android asli.

React Native mendukung TypeScript, yang memungkinkan pengembang memanfaatkan fitur OOP lengkapnya seperti Abstraksi, Polimorfisme, Pewarisan, dan Enkapsulasi. Fitur ini memberdayakan pengembang untuk membuat cuplikan kode yang dapat digunakan kembali. Selain itu, JavaScript mendukung pemrograman fungsional, yang memungkinkan pengembang memiliki kedua sisi OOP dan pemrograman fungsional pada satu platform. Fungsi yang dapat digunakan kembali juga dapat digunakan sebagai objek.

Dalam kode sumber Android non-Compose UI (sistem tampilan), konsep aktivitas digunakan untuk layar, yang menambah kompleksitas pekerjaan karena melihat siklus proses, konteks, dan lainnya. Sebaliknya, semua yang ada di React Native hanyalah sebuah komponen dan dapat digunakan di dalam komponen lain, membuat pengembangan lebih menyenangkan bagi pengembang yang terbiasa dengan paradigma ini.

Bergantung pada skala proyek, disarankan untuk menyusun file sumber daya dan kode sedemikian rupa sehingga dapat dikirim dengan pendekatan seret dan lepas, dengan VS Code yang menangani penautan.

Modul asli biasanya didistribusikan sebagai paket npm, dan menautkan paket ini dengan npm sangatlah mudah. Namun, paket ini belum tentu lebih baik daripada sistem Gradle yang digunakan di Android, dan mungkin ada masalah kompatibilitas dan peringatan penghentian penggunaan yang mengharuskan pengembang menyelesaikannya sendiri.

perlu disebutkan bahwa penggunaan kembali kode bukan hanya tentang menulis kode sekali dan menggunakannya di seluruh platform. Ini juga tentang menulis kode yang mudah dipelihara, diperluas, dan difaktorkan ulang yang lebih tentang bagaimana pengembang dapat menggunakan alat yang tersedia yang disediakan oleh platform.

Pertunjukan

React Native mengkompilasi komponen UI ke kode asli (menggunakan antarmuka render thread untuk menggambar di layar) dan menggunakan jembatan JS untuk berkomunikasi dengan kode JS. Pendekatan ini memastikan bahwa komponen UI bekerja dengan baik, tetapi juga berarti bahwa kinerja aplikasi sangat bergantung pada seberapa baik pengembang dapat memisahkan komponen dari logika JS .

Aplikasi React Native memiliki waktu startup yang sedikit lebih lama pada build rilis dibandingkan dengan aplikasi native. Ini karena mesin JS dan framework React Native perlu diinisialisasi terlebih dahulu untuk menangani UI. Namun, developer Android asli juga dapat mengalami masalah waktu mulai karena kesalahan konfigurasi dalam penyiapan Dagger/Hilt atau proses inisialisasi awal lainnya .

Meskipun React Native memiliki tantangan kinerja, namun tetap dapat memberikan pengalaman pengguna yang baik jika pengembang memahami cara mengoptimalkan kinerja. Dengan menggunakan alat dan teknik pembuatan profil kinerja seperti pemecahan kode , caching , dan menggunakan modul asli , pengembang dapat meningkatkan kinerja aplikasi dan memastikan pengalaman pengguna yang lancar.

Perlu juga dicatat bahwa aplikasi React Native menggunakan lebih banyak memori daripada aplikasi asli karena harus memuat bundel JS dan kerangka kerja. Namun, React Native menggunakan beberapa teknik pengoptimalan untuk mengurangi konsumsi memori, seperti pemuatan komponen yang lambat dan pengumpulan sampah yang berkinerja tinggi. Meskipun demikian, pengembang harus tetap memperhatikan penggunaan memori dalam aplikasi React Native mereka untuk memastikan kinerja yang optimal.

Antarmuka pengguna

Di React Native, cara antarmuka pengguna didesain sangat mirip dengan Compose UI, termasuk animasi. Pada dasarnya, komponen UI hanyalah sebuah fungsi, membuat konsep identik antara kedua platform. Meskipun jenis animasi di React Native ini tidak diaktifkan secara default dan perlu ditambahkan secara manual. API animasi mereka dioptimalkan untuk memastikan berjalan mulus tanpa merender bingkai di utas utama secara langsung. Di sisi lain, meskipun menjalankan animasi pada utas render dimungkinkan dalam sistem tampilan Android , itu belum sepenuhnya matang, menjadikan kode asli pilihan yang lebih baik untuk mengonfigurasi dan menjalankan animasi.

Satu perbedaan utama antara kedua platform adalah Android memiliki konsep tema dan sistem desain bawaan , yang tidak ada di React Native. Namun, ini karena React Native memberi pengembang alat untuk membuat segala jenis mekanisme bertema global di aplikasi. Ini berarti Anda bisa membuat objek tema dan mengimpornya ke komponen apa pun yang Anda buat atau membuat objek gaya di dalam komponen. Setiap pendekatan memiliki pro dan kontra, tergantung pada proyek dan tim.

Salah satu aspek yang menurut saya menantang saat beralih dari Android ke React Native adalah membiasakan diri dengan Flexbox untuk mengelola tata letak. Flexbox lebih merupakan konsep web, dan meskipun mudah digunakan, mungkin sulit untuk dipahami oleh pengembang non-web. Dalam sistem tampilan Android, ada wadah layout yang ditentukan sebelumnya seperti Relative layout dan Constrained layout , yang sudah memiliki properti yang ditentukan.

Perbedaan penting lainnya adalah React Native menggunakan pendekatan pemrograman deklaratif untuk membangun UI, sedangkan sistem tampilan Android didasarkan pada model imperatif (walaupun Compose UI bersifat deklaratif). Ini berarti pengembangan UI di React Native lebih efisien, dan kode yang dihasilkan lebih mudah dibaca dan dipahami.

Secara keseluruhan, meskipun ada beberapa perbedaan antara React Native dan sistem tampilan Android dalam hal pengembangan UI, kedua platform menawarkan alat dan kemampuan canggih untuk membuat antarmuka pengguna yang indah dan berkinerja baik.

Kemampuan Asli

React Native (RN) adalah media tampilan, bukan pengganti lengkap untuk Android/iOS. Oleh karena itu, developer tidak boleh mengharapkan independensi 100% dari kode native. Meskipun RN menawarkan beberapa fitur non-UI, seperti AsyncStorage, untuk fitur lain seperti Elemen, Navigasi, Animasi, Peta, Pemilih Gambar, pengembang harus bergantung pada komunitas dan pustaka meta yang dirancang khusus untuk RN.

Untungnya, RN memiliki komunitas yang dinamis dan tersedia banyak perpustakaan pihak ketiga. Menambahkan pustaka ini ke proyek Anda sering kali membuat Anda tidak perlu menulis kode asli dalam bahasa seperti Java atau Swift. Namun, dalam proyek yang lebih besar, menyentuh kode native seringkali tidak dapat dihindari. Pengembang harus memiliki pengetahuan tentang kode asli untuk memenuhi persyaratan proyek tertentu.

RN hadir dengan AsyncStorage , yang setara dengan Shared Preferences Android . Namun, tidak disarankan untuk menggunakannya karena tidak ada dukungan enkripsi . Sebaliknya, ada opsi yang terbukti oleh komunitas yang melayani tujuan berbeda. Sisi asli memiliki masalah serupa dengan Preferensi Bersama, dan DataStore Android , mendukung enkripsi dan protobuf di luar kotak, menawarkan solusi.

Di sisi asli, Room DB Android yang dibangun dengan SQLite adalah sebuah opsi, sementara pengembang RN sering menggunakan RealmDb . Meskipun kedua database menawarkan fitur serupa, menggunakan RealmDb menambahkan sekitar 3MB ke ukuran aplikasi akhir (terlepas dari kerangka tambahan dan ukuran bundel JS). Migrasi di RoomDB lebih mudah daripada di Realm.

Mengakses fitur khusus perangkat seperti sensor , kamera , dan lokasi mudah dilakukan di RN dengan perpustakaannya yang luar biasa. Pengembang hanya perlu menemukan yang sesuai dengan kebutuhan mereka.

Untuk izin, RN secara teratur memperbarui dokumentasinya dan menyediakan pustaka izin reaksi-asli , yang menawarkan antarmuka sederhana untuk memberikan akses. Di sisi asli, kebijakan privasi sering berubah, dan pengembang mungkin harus menunggu pembaruan perpustakaan untuk sepenuhnya mendukung pengguna Android/iOS terbaru.

Akhirnya, RN memungkinkan pengembang untuk memanggil kode asli melalui kode JS dan sebaliknya menggunakan Modul Asli . Namun, komunikasi ini tidak selalu semulus kelihatannya, mengingat siklus hidup yang berbeda dan status siap dari kode kedua platform. Inisialisasi bisa menjadi tantangan tersendiri.

Perpustakaan dan Ekosistem Pihak Ketiga

Seperti disebutkan sebelumnya, React Native (RN) mendapat manfaat dari komunitas yang kaya. Kebanyakan dari mereka berasal dari lingkungan pengembangan web dan akrab dengan dunia sumber terbuka.

Pustaka pihak ketiga di RN dapat menggunakan pustaka pihak ketiga lain secara internal , sehingga memudahkan untuk menyediakan solusi yang kompatibel untuk pustaka yang tidak digunakan lagi dan membaginya dengan dunia. Dengan NPM sebagai pengelola paket, berbagi kode dengan orang lain menjadi sangat mudah. Dibandingkan dengan Maven dan layanan berbagi repositori birokrasi lainnya di sisi Android asli, NPM memainkan peran penting di sini untuk membantu pertumbuhan komunitas.

Meskipun ada banyak manfaat menggunakan pustaka pihak ketiga, penting untuk diingat bahwa pustaka tersebut dapat menambah kerumitan pada aplikasi dan dapat menimbulkan masalah kompatibilitas atau kerentanan keamanan . Dari perspektif kompatibilitas, pustaka asli lebih aman untuk digunakan.

Penerapan dan Distribusi

React Native unplugged debug build

Proses membangun dan merilis aplikasi di React Native (RN) mirip dengan kode asli. Anda akan memiliki artefak yang sama, dan Anda dapat menerapkannya ke app store mana pun. Namun, build debug berbeda, karena tidak memiliki Hermes, dan apa pun yang disediakan oleh JS tidak akan tersedia.

Sementara di sisi asli, satu-satunya cara untuk menerapkan pembaruan adalah melalui app store, RN mendukung pembaruan over-the-air ( OTA ) melalui fitur yang disebut CodePush . Fitur ini memungkinkan Anda mengupdate aplikasi tanpa mengharuskan pengguna mendownload versi baru dari app store. Namun, pembaruan OTA dapat menimbulkan risiko keamanan, jadi Anda harus berhati-hati saat menggunakannya.

RN menggunakan antarmuka baris perintah (CLI) secara default untuk menerima perintah, memungkinkan pengembang RN membangun artefak dengan alat CI/CD, seperti Fastlane dan GitLab .

Fleksibilitas RN dalam menghadirkan versi baru secara terus-menerus tanpa mengganggu pengguna memungkinkan tim memiliki beberapa strategi penerapan. Dalam skala besar, fleksibilitas ini membantu menyelamatkan bisnis di tahap awal bencana dengan perbaikan segera. Di sisi lain, dengan kode asli, kami harus menunggu proses peninjauan toko dan melalui beban berulang kali dalam beberapa kasus.

RN juga mendapat manfaat dari integrasi dengan layanan Firebase . Anda dapat menggunakan semua layanan hebat yang ditawarkan Firebase, seperti Crashlytics , Remote Config, dan Analytics , di RN tanpa melakukan apa pun dalam kode native, kecuali untuk beberapa penautan manual sederhana.

Pandangan Masa Depan

React Native (rn) terus merilis pembaruan baru untuk mengatasi masalah dan meningkatkan pengembangan dan kinerja. Dengan setiap pembaruan, framework menjadi lebih stabil dan efisien. Misalnya, mereka telah memperkenalkan Fabric sebagai sistem rendering baru, yang dibuat dengan C++ level rendah. Fabric menangani kelambatan rendering karena digabungkannya kode JS dengan thread utama aplikasi, dan memperkenalkan arsitektur baru yang berdampak besar pada siklus pengembangan dan kinerja aplikasi.

React Native telah mendapatkan banyak popularitas di kalangan pengembang, terutama karena kemampuan lintas platformnya, dan tren ini diperkirakan akan terus berlanjut. Menarik juga untuk dicatat bahwa rn menarik banyak pengembang web karena kemiripannya dengan alat dan alur kerja pengembangan web. Akibatnya, banyak pengembang web mulai bereksperimen dengan React Native, dan tanggapannya positif.

Masa depan React Native terlihat cerah, dan diharapkan menjadi salah satu platform dengan pertumbuhan tercepat dalam lima tahun ke depan. Kurva pembelajaran untuk React Native relatif rendah, dan ini membuatnya lebih mudah diakses oleh pengembang yang ingin beralih dari platform lain. React Native juga sangat diminati di pasar kerja, khususnya di pasar startup di seluruh dunia, termasuk Asia Selatan.

Meskipun ada framework lintas platform lain seperti Flutter dan KMM , kecil kemungkinannya KMM akan menjadi alternatif potensial untuk React Native. Meskipun Compose UI Multiplatform telah dirilis, upaya pemasaran Google mungkin memerlukan waktu beberapa tahun sebelum KMM dapat diadopsi secara luas. Selain itu, tim KMM berfokus untuk mengikat JS ke Kotlin dalam waktu dekat, yang berarti bahwa kita mungkin melihat aplikasi yang ditulis dalam React Native berisi modul KMM, atau sebaliknya.

Secara keseluruhan, React Native merupakan framework yang memiliki potensi besar untuk masa depan. Dengan pembaruan konstan, kemampuan lintas platform, dan popularitas yang meningkat, kemungkinan akan tetap menjadi platform terkemuka untuk pengembangan aplikasi.

Kesimpulan

Singkatnya, React Native telah menjadi kerangka kerja yang populer untuk pengembangan aplikasi seluler karena menawarkan banyak fleksibilitas kepada pengembang, mulai dari arsitektur hingga lingkungan pengembangan. Fleksibilitas ini memudahkan pengembang baru untuk mempelajari dasar-dasar React Native. Namun, tanpa arsitektur yang ditentukan, mengelola basis kode dapat menjadi sangat berat, dan pengembang berpengalaman merekomendasikan untuk memperkenalkan struktur dan organisasi ke dalam proyek sejak dini. Kode asli tidak seperti React Native berpendapat sebagian besar aspek kode (arsitektur, desain, dan struktur) untuk mencegah pengembang dari potensi kesalahan.

React Native mendukung TypeScript, yang memungkinkan pengembang memanfaatkan fitur OOP lengkapnya dan membuat cuplikan kode yang dapat digunakan kembali.

Secara keseluruhan, saya merekomendasikan RN daripada pengembangan asli untuk proyek skala kecil dan menengah terutama ketika rencana bisnis sedang dalam pengembangan dan produk membutuhkan fleksibilitas. Ketika produk membutuhkan kinerja dan melakukan pemrosesan besar di sisi klien (pemrosesan gambar, game, atau beberapa aplikasi Web3 yang memerlukan sensor), mungkin kode asli berfungsi lebih baik dalam jangka panjang.

Jika Anda ingin melihat perbedaan antara keduanya, silakan lihat proyek Kotlin saya yang ditulis ulang di React Native dihttp://github.com/thesiamak/sendit-react-native