


Keadaan dalam Komponen UI
Apabila kita mula memperkenalkan keadaan ke dalam komponen UI, ia sering menggoda untuk melakukan sesuatu seperti ini:
Contoh Kaunter Mudah dalam Svelte:
<script> let count = $state(0); </script> <button onclick="{()"> count++}> clicks: {count} </button>
Masalah
Kami menggunakan Svelte di sini tetapi isu yang sama boleh digunakan dalam mana-mana rangka kerja UI.
Secara langsung, kami telah menggabungkan logik keadaan kami dengan komponen - fungsi kenaikan dikodkan terus dalam templat.
Dengan persediaan ini kami tidak boleh menggunakan semula logik pembilang dalam:
- komponen UI lain
- logik perniagaan lain yang memerlukan kaunter
- rangka kerja UI lain
Kami juga tidak boleh menguji logik pembilang tanpa memaparkan komponen. Jika komponen mempunyai fungsi lain yang digabungkan dengannya, mengasingkan logik pembilang tidak akan dapat dilakukan.
Penyelesaian:
Asingkan logik keadaan daripada komponen UI supaya ia boleh dilaksanakan dan diuji secara bebas. Ini akan menjadikan logik lebih boleh digunakan semula dan komponen UI hanya perlu mendengar perubahan keadaan dan membuat. Pertimbangkan perkara berikut:
<script> import { RxCounter } from './RxCounter'; const [count, { increment }] = RxCounter(); </script> <button onclick="{increment}"> Count: {$count} </button>
Lihat contoh penuh di StackBlitz
Jika anda bandingkan di atas dengan contoh asal kami, semua logik untuk kaunter kini terkandung dalam RxCounter (kami akan tunjukkan pelaksanaannya kemudian).
count ialah RxJS Observable yang mengeluarkan keadaan kiraan baharu. kenaikan ialah kaedah tindakan yang boleh dipanggil oleh UI untuk menggunakan perubahan keadaan.
Svelte mempunyai cara terbina dalam melanggan yang boleh diperhatikan dalam templat seperti yang dilihat dengan pembolehubah templat $count. Melanggan sesuatu yang boleh diperhatikan dalam mana-mana rangka kerja UI tidaklah begitu sukar dan banyak rangka kerja mempunyai API untuk membantu mencapainya.
Melaksanakan RxCounter
Maklumat dan Penafian: Kami akan menggunakan API Reactables yang dicipta oleh pengarang. Ia adalah penyelesaian pengurusan negeri yang memanfaatkan RxJS untuk menjadikan pengaturcaraan reaktif lebih mudah.
Dapatkan Pakej Teras Reactables dan buat RxCounter.
npm i @reactables/core
import { RxBuilder } from '@reactables/core'; export const RxCounter = () => RxBuilder({ initialState: 0, reducers: { increment: (count) => count + 1, }, });
RxBuilder mengembalikan Reactable.
Reactable ialah tuple dengan item pertamanya ialah RxJS Observable yang memancarkan perubahan keadaan dan item kedua ialah kamus kaedah tindakan untuk mencetuskan kemas kini keadaan.
Keadaan adalah reaktif, bermakna keadaan bertindak balas kepada perubahan melalui fungsi pengurangnya. Apabila tindakan kenaikan yang dicetuskan oleh UI diterima, yang boleh bertindak balas bertindak balas dan yang boleh diperhatikan mengeluarkan keadaan baharu.
Nota RxCounter kini dipisahkan sepenuhnya daripada lapisan paparan dan boleh digunakan dalam mana-mana rangka kerja UI!
Menguji Kaunter
Untuk menguji Reactable, kami melanggan keadaan boleh diperhatikan dan menggunakan kaedah tindakannya untuk menguji kelakuannya. Kita boleh menegaskan nilai yang dipancarkan yang boleh diperhatikan sepadan dengan kelakuan yang diingini.
Ini boleh dilakukan dengan Ujian Marmar terbina dalam RxJS.
<script> let count = $state(0); </script> <button onclick="{()"> count++}> clicks: {count} </button>
Memanjangkan Kaunter
Dengan logik keadaan yang diasingkan daripada paparan, kami juga boleh melanjutkan fungsi RxCounter dan mencipta RxDoubleCounter yang mempunyai keupayaan untuk menggandakan kiraan.
<script> import { RxCounter } from './RxCounter'; const [count, { increment }] = RxCounter(); </script> <button onclick="{increment}"> Count: {$count} </button>
Lihat contoh penuh di StackBlitz
Kesimpulan
Melaksanakan logik keadaan secara langsung dalam komponen UI menjadikan logik lebih sukar untuk digunakan semula dan diuji.
Kami boleh memprogramkan logik keadaan secara reaktif dengan Reactables dan mengujinya secara berasingan. Ini menghasilkan unit logik keadaan reaktif yang sangat boleh digunakan semula dalam kedua-dua lapisan paparan dan logik.
Kami melakukan contoh kaunter yang mudah di sini, tetapi Reactables boleh dikembangkan dan boleh digubah untuk senario pengurusan keadaan yang lebih kompleks (iaitu pengambilan data, borang dll...). Semak dokumen untuk mengetahui lebih lanjut!
Atas ialah kandungan terperinci Logik Keadaan Boleh Digunakan Semula, Boleh Diperluas dan Boleh Diuji dengan Pengaturcaraan Reaktif.. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Perbezaan utama antara Python dan JavaScript ialah sistem jenis dan senario aplikasi. 1. Python menggunakan jenis dinamik, sesuai untuk pengkomputeran saintifik dan analisis data. 2. JavaScript mengamalkan jenis yang lemah dan digunakan secara meluas dalam pembangunan depan dan stack penuh. Kedua -duanya mempunyai kelebihan mereka sendiri dalam pengaturcaraan dan pengoptimuman prestasi yang tidak segerak, dan harus diputuskan mengikut keperluan projek ketika memilih.

Sama ada untuk memilih Python atau JavaScript bergantung kepada jenis projek: 1) Pilih Python untuk Sains Data dan Tugas Automasi; 2) Pilih JavaScript untuk pembangunan front-end dan penuh. Python disukai untuk perpustakaannya yang kuat dalam pemprosesan data dan automasi, sementara JavaScript sangat diperlukan untuk kelebihannya dalam interaksi web dan pembangunan stack penuh.

Python dan JavaScript masing -masing mempunyai kelebihan mereka sendiri, dan pilihan bergantung kepada keperluan projek dan keutamaan peribadi. 1. Python mudah dipelajari, dengan sintaks ringkas, sesuai untuk sains data dan pembangunan back-end, tetapi mempunyai kelajuan pelaksanaan yang perlahan. 2. JavaScript berada di mana-mana dalam pembangunan front-end dan mempunyai keupayaan pengaturcaraan tak segerak yang kuat. Node.js menjadikannya sesuai untuk pembangunan penuh, tetapi sintaks mungkin rumit dan rawan kesilapan.

Javascriptisnotbuiltoncorc; it'saninterpretedlanguagethatrunsonenginesoftenwritteninc .1) javascriptwasdesignedasalightweight, interpratedlanguageforwebbrowsers.2)

JavaScript boleh digunakan untuk pembangunan front-end dan back-end. Bahagian depan meningkatkan pengalaman pengguna melalui operasi DOM, dan back-end mengendalikan tugas pelayan melalui Node.js. 1. Contoh front-end: Tukar kandungan teks laman web. 2. Contoh backend: Buat pelayan Node.js.

Memilih Python atau JavaScript harus berdasarkan perkembangan kerjaya, keluk pembelajaran dan ekosistem: 1) Pembangunan Kerjaya: Python sesuai untuk sains data dan pembangunan back-end, sementara JavaScript sesuai untuk pembangunan depan dan penuh. 2) Kurva Pembelajaran: Sintaks Python adalah ringkas dan sesuai untuk pemula; Sintaks JavaScript adalah fleksibel. 3) Ekosistem: Python mempunyai perpustakaan pengkomputeran saintifik yang kaya, dan JavaScript mempunyai rangka kerja front-end yang kuat.

Kuasa rangka kerja JavaScript terletak pada pembangunan yang memudahkan, meningkatkan pengalaman pengguna dan prestasi aplikasi. Apabila memilih rangka kerja, pertimbangkan: 1.

Pengenalan Saya tahu anda mungkin merasa pelik, apa sebenarnya yang perlu dilakukan oleh JavaScript, C dan penyemak imbas? Mereka seolah -olah tidak berkaitan, tetapi sebenarnya, mereka memainkan peranan yang sangat penting dalam pembangunan web moden. Hari ini kita akan membincangkan hubungan rapat antara ketiga -tiga ini. Melalui artikel ini, anda akan mempelajari bagaimana JavaScript berjalan dalam penyemak imbas, peranan C dalam enjin pelayar, dan bagaimana mereka bekerjasama untuk memacu rendering dan interaksi laman web. Kita semua tahu hubungan antara JavaScript dan penyemak imbas. JavaScript adalah bahasa utama pembangunan front-end. Ia berjalan secara langsung di penyemak imbas, menjadikan laman web jelas dan menarik. Adakah anda pernah tertanya -tanya mengapa Javascr


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

Dreamweaver Mac版
Alat pembangunan web visual

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.
