Dalam artikel ini, kami akan memahami cara createStore dalam kod sumber Zustand ditulis/berfungsi.
createStore dieksport daripada vanilla.ts dan anda akan menemuinya di hujung fail.
export const createStore = ((createState) => createState ? createStoreImpl(createState) : createStoreImpl) as CreateStore
createStore ialah fungsi anak panah yang menerima parameter yang dipanggil createState. jika createState wujud, createStoreImpl(createState) dipanggil.
createStoreImpl
const createStoreImpl: CreateStoreImpl = (createState) => { type TState = ReturnType<typeof createstate> type Listener = (state: TState, prevState: TState) => void let state: TState const listeners: Set<listener> = new Set() const setState: StoreApi<tstate>['setState'] = (partial, replace) => { // TODO: Remove type assertion once https://github.com/microsoft/TypeScript/issues/37663 is resolved // https://github.com/microsoft/TypeScript/issues/37663#issuecomment-759728342 const nextState = typeof partial === 'function' ? (partial as (state: TState) => TState)(state) : partial if (!Object.is(nextState, state)) { const previousState = state state = (replace ?? (typeof nextState !== 'object' || nextState === null)) ? (nextState as TState) : Object.assign({}, state, nextState) listeners.forEach((listener) => listener(state, previousState)) } } const getState: StoreApi<tstate>['getState'] = () => state const getInitialState: StoreApi<tstate>['getInitialState'] = () => initialState const subscribe: StoreApi<tstate>['subscribe'] = (listener) => { listeners.add(listener) // Unsubscribe return () => listeners.delete(listener) } const api = { setState, getState, getInitialState, subscribe } const initialState = (state = createState(setState, getState, api)) return api as any } </tstate></tstate></tstate></tstate></listener></typeof>
Dalam artikel kami sebelum ini, saya telah menulis tentang cara setState, subscribe berfungsi. Kami akan meliputi fungsi yang selebihnya seperti getState, getInitialState, createState.
getState
getState hanya mengembalikan keadaan yang diisytiharkan di bahagian atas fungsi createStoreImpl ini.
const getState: StoreApi<tstate>['getState'] = () => state </tstate>
getInitialState
getInitialState mengembalikan initialState.
const getInitialState: StoreApi<tstate>['getInitialState'] = () => initialState </tstate>
createState
createState digunakan untuk memulakan pembolehubah keadaan.
const createStoreImpl: CreateStoreImpl = (createState) => {
createState ialah parameter dalam createStoreImpl. Mari jalankan beberapa percubaan menggunakan contoh tunjuk cara yang disediakan dalam repo Zustand.
Ini pada asasnya hanyalah perkara yang anda lakukan untuk "buat"
// Create the store using Zustand const useStore = create((set) => ({ count: 1, inc: () => set((state) => ({ count: state.count + 1 })), }));
Pemulaan keadaan berlaku dalam vanilla.ts pada L93, walaupun create pada asalnya dieksport daripada React, react.ts secara dalaman memanggil createStore dalam vanilla.ts.
Jadi bagaimanakah cara memanggil createState memulakan keadaan?
const initialState = (state = createState(setState, getState, api))
Helahnya terletak pada memanggil fungsi anak panah, createState. Daripada coretan kod di atas, anda boleh melihat createState dipanggil dengan setState, getState, api
Mari jalankan beberapa percubaan dengan maklumat ini. Mari lulus fungsi tersuai bernama ujian sebagai parameter tanpa parameter asal.
Imej di atas menunjukkan fungsi ujian tersuai yang saya tambahkan untuk menunjukkan cara parameter dihantar ke fungsi createState.
mari kita lihat fungsi ujian dalaman ini dalam tindakan. Untuk kami mengakses fungsi ujian ini, contoh berikut menunjukkan cara createStore boleh dimulakan dengan parameter ujian yang baru ditambah ini.
// Create the store using Zustand const useStore = create((set, get, api, test) => ({ count: 1, inc: () => set((state) => ({ count: state.count + 1 })), test: () => test() }));
Oleh kerana kami mendedahkan ujian dalam vanilla.mjs seperti yang ditunjukkan di bawah, anda akan mempunyai akses kepada fungsi ini apabila anda memulakan fungsi cipta
Saya mencetuskan fungsi ujian ini apabila butang dalam contoh demo diklik.
Ini, seterusnya, memanggil fungsi ujian.
Ini ialah beberapa penggunaan fungsi anak panah JavaScript lanjutan dan oh, kami juga baru menambah fungsi ujian tersuai dan digunakan dalam apl tunjuk cara. Itu bagus.
Tentang kami:
Di Think Throo, kami berada dalam misi untuk mengajar amalan terbaik yang diilhamkan oleh projek sumber terbuka.
10x kemahiran pengekodan anda dengan mempraktikkan konsep seni bina lanjutan dalam Next.js/React, pelajari amalan terbaik dan bina projek gred pengeluaran.
Kami adalah sumber terbuka — https://github.com/thinkthroo/thinkthroo (Beri kami bintang!)
Ingin membina sistem web yang dipesan lebih dahulu untuk perniagaan anda? Hubungi kami di hello@thinkthroo.com
Mengenai pengarang:
Hei, saya Ram. Saya seorang jurutera perisian/OSS Tinkerer yang bersemangat.
Lihat tapak web saya: https://www.ramunarasinga.com/
Rujukan:
- https://github.com/pmndrs/zustand/blob/main/src/vanilla.ts#L97
Atas ialah kandungan terperinci createStore dalam kod sumber negeri dijelaskan.. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Saya membina aplikasi SaaS multi-penyewa berfungsi (aplikasi edTech) dengan alat teknologi harian anda dan anda boleh melakukan perkara yang sama. Pertama, apakah aplikasi SaaS multi-penyewa? Aplikasi SaaS Multi-penyewa membolehkan anda melayani beberapa pelanggan dari Sing

Artikel ini menunjukkan integrasi frontend dengan backend yang dijamin oleh permit, membina aplikasi edtech SaaS yang berfungsi menggunakan Next.Js. Frontend mengambil kebenaran pengguna untuk mengawal penglihatan UI dan memastikan permintaan API mematuhi dasar peranan

JavaScript adalah bahasa utama pembangunan web moden dan digunakan secara meluas untuk kepelbagaian dan fleksibiliti. 1) Pembangunan front-end: Membina laman web dinamik dan aplikasi satu halaman melalui operasi DOM dan kerangka moden (seperti React, Vue.js, sudut). 2) Pembangunan sisi pelayan: Node.js menggunakan model I/O yang tidak menyekat untuk mengendalikan aplikasi konkurensi tinggi dan masa nyata. 3) Pembangunan aplikasi mudah alih dan desktop: Pembangunan silang platform direalisasikan melalui reaktnatif dan elektron untuk meningkatkan kecekapan pembangunan.

Trend terkini dalam JavaScript termasuk kebangkitan TypeScript, populariti kerangka dan perpustakaan moden, dan penerapan webassembly. Prospek masa depan meliputi sistem jenis yang lebih berkuasa, pembangunan JavaScript, pengembangan kecerdasan buatan dan pembelajaran mesin, dan potensi pengkomputeran IoT dan kelebihan.

JavaScript adalah asas kepada pembangunan web moden, dan fungsi utamanya termasuk pengaturcaraan yang didorong oleh peristiwa, penjanaan kandungan dinamik dan pengaturcaraan tak segerak. 1) Pengaturcaraan yang didorong oleh peristiwa membolehkan laman web berubah secara dinamik mengikut operasi pengguna. 2) Penjanaan kandungan dinamik membolehkan kandungan halaman diselaraskan mengikut syarat. 3) Pengaturcaraan Asynchronous memastikan bahawa antara muka pengguna tidak disekat. JavaScript digunakan secara meluas dalam interaksi web, aplikasi satu halaman dan pembangunan sisi pelayan, sangat meningkatkan fleksibiliti pengalaman pengguna dan pembangunan silang platform.

Python lebih sesuai untuk sains data dan pembelajaran mesin, manakala JavaScript lebih sesuai untuk pembangunan front-end dan penuh. 1. Python terkenal dengan sintaks ringkas dan ekosistem perpustakaan yang kaya, dan sesuai untuk analisis data dan pembangunan web. 2. JavaScript adalah teras pembangunan front-end. Node.js menyokong pengaturcaraan sisi pelayan dan sesuai untuk pembangunan stack penuh.

JavaScript tidak memerlukan pemasangan kerana ia sudah dibina dalam pelayar moden. Anda hanya memerlukan editor teks dan penyemak imbas untuk memulakan. 1) Dalam persekitaran penyemak imbas, jalankan dengan memasukkan fail HTML melalui tag. 2) Dalam persekitaran Node.js, selepas memuat turun dan memasang node.js, jalankan fail JavaScript melalui baris arahan.

Cara Menghantar Pemberitahuan Tugas di Quartz terlebih dahulu Apabila menggunakan pemasa kuarza untuk menjadualkan tugas, masa pelaksanaan tugas ditetapkan oleh ekspresi cron. Sekarang ...


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

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

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

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular