Pembangunan perisian moden sering memerlukan pendekatan inovatif untuk mengurus kebergantungan, terutamanya dalam projek JavaScript berskala besar. Satu pendekatan sedemikian adalah menggunakan berbilang versi pakej yang sama dalam satu projek. Kaedah ini, walaupun kelihatan tidak konvensional, menangani pelbagai keperluan seperti memastikan sokongan sistem warisan, menjalankan penogol ciri atau memudahkan ujian A/B.
Dalam catatan blog ini, kami akan menyelidiki sebab di sebalik penggunaan berbilang versi pakej, dengan tumpuan pada togol ciri dan ujian A/B, serta meneroka cara Bit boleh memudahkan proses yang kompleks ini.
Sistem warisan selalunya bergantung pada versi kebergantungan yang lebih lama. Memperkenalkan versi baharu mungkin menyebabkan ketidakserasian. Menggunakan berbilang versi memastikan ciri baharu boleh memanfaatkan perpustakaan yang dikemas kini manakala sistem lama kekal stabil.
Togol ciri membolehkan pembangun mengawal ketersediaan ciri tertentu tanpa mengubah suai pangkalan kod. Pendekatan ini amat berguna apabila mengeluarkan ciri secara berperingkat atau menguji kesannya.
Togol Lepaskan: Tangguhkan keluaran awam sesuatu ciri sambil memastikan kodnya digabungkan dan diuji dalam cawangan utama.
Togol Eksperimen:(Ujian A/B): Benarkan ciri ujian dengan segmen pengguna yang berbeza untuk menentukan pelaksanaan yang optimum.
Togol Ops: Menyediakan pasukan operasi dengan keupayaan untuk mendayakan atau melumpuhkan ciri tanpa menggunakan kod baharu.
Togol ciri mungkin memerlukan berbilang versi pakej atau komponen apabila togol melibatkan perubahan ketara, seperti menaik taraf perpustakaan atau mengubah komponen teras.
Bit menawarkan arahan bit snap untuk versi komponen anda dengan cincang dan bukannya Versi Semantik, untuk menunjukkan versi belum sedia untuk dikeluarkan (arahan itu juga melaksanakan saluran paip binaan yang sedikit berbeza, sewajarnya).
Contohnya:
'bit snap' => package-name@5475049d02fafa0eaf6885a06d36e42e0ffdc4a3 'bit tag' => package-name@1.2.3
Walau bagaimanapun, mempunyai cincangan sebagai versi komponen tidak memberikan sebarang maklumat tentang tujuannya, versi keluaran induknya atau sama ada "cawangan" sejarah komponen ini mempunyai lelaran tambahan.
Snap bit berguna sebagai analogi Bit untuk git commit tetapi bukan untuk versi keluaran percubaan yang harus disepadukan ke dalam pengeluaran.
Untuk memberikan maklumat lanjut, disyorkan untuk menggunakan pilihan prakeluaran. Contohnya:
'bit snap' => package-name@5475049d02fafa0eaf6885a06d36e42e0ffdc4a3 'bit tag' => package-name@1.2.3
Apabila menggunakan berbilang versi pakej/komponen Bit, aliasing kebergantungan adalah kunci. Pendekatan ini membolehkan pasukan mengekalkan berbilang versi pakej dalam projek yang sama.
bit tag forms/sign-in -m "add SSO option" --increment prerelease --prerelease-id beta
Nama Alias memudahkan untuk membezakan antara versi:
{ "dependencies": { "@my-org/my-scope.forms.sign-in": "0.0.1", "@my-org/my-scope.forms.sign-in-sso": "npm:@my-org/my-scope.forms/sign-in@0.0.2-beta.0", }
Atas ialah kandungan terperinci Menggunakan Berbilang Versi Pakej dalam Satu Projek: Mengapa dan Bagaimana. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!