Jika anda ingin meningkatkan kualiti keseluruhan kod anda, anda mungkin mahu memastikan model data anda dipisahkan dengan kemas daripada pandangan asas.
Rangka kerja Functional-Reactive atau pustaka UI seperti Rimmel.js, yang mempunyai sokongan penuh untuk Observables, membolehkan anda mentakrifkan model anda sebagai strim Boleh Diperhatikan (cth.: data masuk mudah, strim keluar data) sebagai tambahan kepada reka bentuk yang kurang dikenali corak yang merupakan penyesuai acara.
Penyesuai acara membantu anda memetakan sebarang acara sumber (Cth.: MouseEvent, PointerEvent, KeyboardEvent, dll) DOM kepada format yang sebenarnya digunakan oleh model data anda, supaya ia akan dibebaskan daripada tugas penukaran ini dan akhirnya dipisahkan daripada UI.
Rimmel memudahkan untuk menyambungkan strim sedemikian ke DOM:
import { rml } from 'rimmel'; const component = () => { const total = new Subject().pipe( map(x => doSomethingWith(x)), ); return rml` <button onclick="${stream}">click me</button> <div id="display">${stream}</div> `; }
Pengikatan adalah remeh: Rimmel menyambungkan peristiwa klik yang datang daripada butang terus ke strim boleh diperhatikan anda, yang akan menerima contoh PointerEvent setiap kali butang diklik.
Setakat ini baik. Bagaimana jika strim anda perlu mengambil data daripada berbilang sumber dan berkelakuan berbeza bergantung pada setiap sumber?
Mari buat pembilang mudah dengan butang kenaikan dan pengurangan, masing-masing menambah atau menolak satu daripadanya.
import { scan } from 'rxjs'; import { rml } from 'rimmel'; const component = () => { const total = new BehaviorSubject(0).pipe( scan((old, new) => old+new, 0), ); return rml` <button onclick="${() => total.next(1)}">inc</button> <button onclick="${() => total.next(-1)}">dec</button> <div>${total}</div> `; }
Ini berfungsi, tetapi bahagian templat termasuk beberapa logik, yang merupakan anti-corak. Sebaik-baiknya kita harus berusaha untuk mempunyai templat tanpa logik untuk memaksimumkan kebolehujian secara keseluruhan.
Jadi, dengan Rimmel 1.2 anda mempunyai ciri baharu, Event Mappers, yang membantu dengan tepat. Ia membantu anda memetakan peristiwa DOM ke dalam perkara yang diperlukan oleh model anda, supaya anda boleh memastikan logik diasingkan dengan sempurna daripada templat. Begini caranya.
import { map, scan } from 'rxjs'; import { rml, reversePipe } from 'rimmel'; const Inc = reversePipe(map(() => 1)); const Dec = reversePipe(map(() => -1)); const component = () => { const total = new BehaviorSubject(0).pipe( scan((old, new) => old+new, 0), ); return rml` <button onclick="${Inc(total)}">inc</button> <button onclick="${Dec(total)}">dec</button> <div>${total}</div> `; };
reversePipe ialah penambahan inovatif di sini: alat penciptaan saluran paip yang berfungsi bertentangan dengan fungsi pipe() dalam RxJS. Walaupun yang terakhir menggunakan transformasi pada output strim, reversePipe() menggunakannya pada input.
Dengan cara ini anda pasti Subjek/BehaviorSubject/Pemerhati/EventListener aliran utama anda sentiasa mendapat data dalam format yang anda inginkan dan anda menyimpan penyesuai anda sebagai kebimbangan yang berasingan.
Anda boleh menggunakan mana-mana operator RxJS dalam saluran paip terbalik anda. Adakah anda hanya mahu menapis acara tertentu, seperti apabila pengguna menekan Enter, bukannya mana-mana kunci lain? Hanya gunakan operator penapis:
import { Subject, filter, map } from 'rxjs'; import { rml, inputPipe } from 'rimmel'; const UpperOnEnter = inputPipe( filter((e: Event) => e.key == 'Enter'), map((e: Event) => e.target.value.toUpperCase()), ); const Component = () => { const state = new Subject(); return rml` Type some text and hit Enter<br> <input onkeydown="${UpperOnEnter(state)}"> <div>${state}</div> `; };
Mengenai ujian unit, ini adalah tambahan kecil tetapi berguna yang akan menjadikan ujian lebih mudah dan lebih cekap.
Lihat pemeta acara yang sedang beraksi di Stackblitz
iniAtas ialah kandungan terperinci Menggunakan Pemeta Peristiwa dengan Rimmel.js: pengenalan ringkas. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kedua -dua pilihan Python dan JavaScript dalam persekitaran pembangunan adalah penting. 1) Persekitaran pembangunan Python termasuk Pycharm, Jupyternotebook dan Anaconda, yang sesuai untuk sains data dan prototaip cepat. 2) Persekitaran pembangunan JavaScript termasuk node.js, vscode dan webpack, yang sesuai untuk pembangunan front-end dan back-end. Memilih alat yang betul mengikut keperluan projek dapat meningkatkan kecekapan pembangunan dan kadar kejayaan projek.

Ya, teras enjin JavaScript ditulis dalam C. 1) Bahasa C menyediakan prestasi yang efisien dan kawalan asas, yang sesuai untuk pembangunan enjin JavaScript. 2) Mengambil enjin V8 sebagai contoh, terasnya ditulis dalam C, menggabungkan kecekapan dan ciri-ciri berorientasikan objek C. 3) Prinsip kerja enjin JavaScript termasuk parsing, penyusun dan pelaksanaan, dan bahasa C memainkan peranan penting dalam proses ini.

JavaScript adalah di tengah -tengah laman web moden kerana ia meningkatkan interaktiviti dan dinamik laman web. 1) Ia membolehkan untuk menukar kandungan tanpa menyegarkan halaman, 2) memanipulasi laman web melalui Domapi, 3) menyokong kesan interaktif kompleks seperti animasi dan drag-and-drop, 4) mengoptimumkan prestasi dan amalan terbaik untuk meningkatkan pengalaman pengguna.

C dan JavaScript mencapai interoperabilitas melalui webassembly. 1) Kod C disusun ke dalam modul WebAssembly dan diperkenalkan ke dalam persekitaran JavaScript untuk meningkatkan kuasa pengkomputeran. 2) Dalam pembangunan permainan, C mengendalikan enjin fizik dan rendering grafik, dan JavaScript bertanggungjawab untuk logik permainan dan antara muka pengguna.

JavaScript digunakan secara meluas di laman web, aplikasi mudah alih, aplikasi desktop dan pengaturcaraan sisi pelayan. 1) Dalam pembangunan laman web, JavaScript mengendalikan DOM bersama -sama dengan HTML dan CSS untuk mencapai kesan dinamik dan menyokong rangka kerja seperti JQuery dan React. 2) Melalui reaktnatif dan ionik, JavaScript digunakan untuk membangunkan aplikasi mudah alih rentas platform. 3) Rangka kerja elektron membolehkan JavaScript membina aplikasi desktop. 4) Node.js membolehkan JavaScript berjalan di sisi pelayan dan menyokong permintaan serentak yang tinggi.

Python lebih sesuai untuk sains data dan automasi, manakala JavaScript lebih sesuai untuk pembangunan front-end dan penuh. 1. Python berfungsi dengan baik dalam sains data dan pembelajaran mesin, menggunakan perpustakaan seperti numpy dan panda untuk pemprosesan data dan pemodelan. 2. Python adalah ringkas dan cekap dalam automasi dan skrip. 3. JavaScript sangat diperlukan dalam pembangunan front-end dan digunakan untuk membina laman web dinamik dan aplikasi satu halaman. 4. JavaScript memainkan peranan dalam pembangunan back-end melalui Node.js dan menyokong pembangunan stack penuh.

C dan C memainkan peranan penting dalam enjin JavaScript, terutamanya digunakan untuk melaksanakan jurubahasa dan penyusun JIT. 1) C digunakan untuk menghuraikan kod sumber JavaScript dan menghasilkan pokok sintaks abstrak. 2) C bertanggungjawab untuk menjana dan melaksanakan bytecode. 3) C melaksanakan pengkompil JIT, mengoptimumkan dan menyusun kod hot-spot semasa runtime, dan dengan ketara meningkatkan kecekapan pelaksanaan JavaScript.

Aplikasi JavaScript di dunia nyata termasuk pembangunan depan dan back-end. 1) Memaparkan aplikasi front-end dengan membina aplikasi senarai TODO, yang melibatkan operasi DOM dan pemprosesan acara. 2) Membina Restfulapi melalui Node.js dan menyatakan untuk menunjukkan aplikasi back-end.


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

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft
