Разберете как можете да използвате управлението на състоянието, за да захранвате вашите Astro приложения.

Когато създавате приложение с рамката Astro, може да се чудите как да управлявате състоянието на приложението или да го споделяте между компоненти и рамки. Nano Stores е един от най-добрите държавни мениджъри за Astro, благодарение на факта, че работи с React, Preact, Svelte, Solid, Lit, Angular и Vanilla JS.

Научете как да управлявате състоянието в рамките на Astro проект. Следвайте прости стъпки, за да създадете основно приложение за водене на бележки, което използва Nano Stores за управление на състоянието и споделя състоянието си между React и Solid.js компонент.

Какво е Astro?

Рамката Astro ви позволява да създавате уеб приложения върху популярни UI рамки като React, Preact, Vue или Svelte. Рамката използва a компонентно базирана архитектура, така че всяка страница в Astro се състои от няколко компонента.

За да ускори времето за зареждане на страницата, рамката свежда до минимум използването на JavaScript от страна на клиента и вместо това предварително изобразява страници на сървъра.

instagram viewer

Astro е проектиран да бъде идеалният инструмент за публикуване на уебсайтове, фокусирани върху съдържанието. Помислете за блогове, целеви страници, новинарски уебсайтове и други страници, които се фокусират върху съдържанието вместо върху интерактивността. За компонентите, които маркирате като интерактивни, рамката ще изпрати само минималния JavaScript, необходим за активиране на тази интерактивност.

Инсталиране и настройка

Ако вече имате работещ Astro проект, пропуснете този раздел.

Но ако нямате Astro проект, ще трябва да създадете такъв. Единственото изискване за това е наличието Node.js инсталиран на вашата локална машина за разработка.

За да създадете чисто нов Astro проект, стартирайте командния ред, cd в директорията в който искате да създадете своя проект, след това изпълнете следната команда:

npm create astro@latest

Отговорете с „y“, за да инсталирате Astro и въведете име за името на папката на вашия проект. Можете да се обърнете към Astro's официален урок за настройка ако сте заседнали по пътя.

След като приключите със създаването на проекта, проследете това със следната команда (това добавя React към проекта):

npx astro add react

И накрая, инсталирайте Nano Stores за React, като изпълните следната команда:

npm i nanostores @nanostores/react

Все още на вашия терминал, влезте в главната папка на проекта и стартирайте приложението с някоя от следните команди (в зависимост от това коя от тях използвате):

npm run dev

Или:

yarn run dev

Или:

pnpm run dev

Отидете на http://localhost: 3000 във вашия уеб браузър, за да видите визуализация на вашия уебсайт.

След като вашият Astro проект е готов, следващата стъпка е да създадете хранилище за данните на приложението.

Създаване на магазин за бележки

Създайте файл с име noteStore.js файл вътре в /src директория в корена на вашето приложение. Вътре в този файл използвайте атом() функция от наномагазини за да създадете магазин за бележки:

import { atom } from"nanostores"

exportconst notes = atom([])

exportfunctionaddNote(note) {
notes.set([...notes.get(), note])
console.log("Added note: ", note.get())
}

The добави бележка() функцията приема бележка като свой аргумент и я съхранява в хранилището за бележки. Той използва оператора за разпространение, когато съхранява бележката, за да избегне мутация на данните. Операторът за разпространение е a Съкращение на JavaScript за копиране на обекти.

Създаване на потребителски интерфейс на приложението за водене на бележки

Потребителският интерфейс просто ще се състои от вход за събиране на бележката и бутон, който при щракване добавя бележката към магазина.

Вътре в src/компоненти директория, създайте нов файл с име NoteAddButton.jsx. След това поставете следния код във файла:

import {useState} from"react"
import {addNote, notes} from"../noteStore"

exportdefaultfunctionNoteAdder() {
const [userNote, setUserNote] = useState('')

return(
<>

"text" name="note" id="note"
onChange={(event) => setUserNote(event.target.value)} />


    {
    $notes.map((note, index) => {
  • {note}</li>
    })
    }
    </ul>
    </>
    )
    }

Този код добавя бележката към състоянието на компонента, докато въвеждате във входа. След това, когато щракнете върху бутона, той записва бележката в магазина. Той също така грабва бележките от магазина и ги показва в неподреден списък. С този подход бележката ще се покаже на страницата веднага след щракване върху Запазване бутон.

Сега във вашия страници/индекс.astro файл, трябва да импортирате NoteAddButton и го използвайте в рамките на тагове:

import NoteAddButton from"../components/NoteAddButton.jsx"

"Welcome to Astro.">


</main>
</Layout>

// Other code

Ако сега се върнете в браузъра си, ще намерите елемента за въвеждане и бутона, изобразени на страницата. Въведете нещо във входа и щракнете върху Запазване бутон. Бележката веднага ще се покаже на страницата и ще остане на страницата дори след като опресните браузъра си.

Споделяне на състояние между две рамки

Да приемем, че искате да споделите състоянието между React и Solid.js. Първото нещо, което трябва да направите, е да добавите Solid към вашия проект, като изпълните следната команда:

npx astro add solid

След това добавете Nano Stores за solid.js, като изпълните:

npm i nanostores @nanostores/solid

За да създадете потребителския интерфейс в solid.js, влезте в src/компоненти директория и създайте нов файл с име Notes.js. Отворете файла и създайте компонента Notes вътре в него:

import {useStore} from"@nanostores/solid"
import {notes} from"../noteStore"
import {For} from"solid-js"

exportdefaultfunctionNotes() {
const $notes = useStore(notes)

return(
<>

My notes</h1>


    {(note) => <li>{note}li>}
    </For>
    </ul>
    </>
    )
    }

В този файл импортирате бележките от магазина, преминавате през всяка от бележките и я показвате на страницата.

За да покаже горното Забележка компонент, създаден със Solid.js, просто отидете на вашия страници/индекс.astro файл, импортиране NoteAddButton и го използвайте в рамките на тагове:

import NodeAddButton from"../components/NoteAddButton.jsx"
import Nodes from"../components/Notes.jsx"

"Welcome to Astro.">



</main>
</Layout>

// Other code

Сега се върнете в браузъра си, въведете нещо във входа и щракнете върху Запазване бутон. Бележката ще се покаже на страницата и ще се запази между изобразяванията.

Други нови функции на Astro

Използвайки тези техники, можете да управлявате състоянието във вашето приложение Astro и да го споделяте между компоненти и рамки. Но Astro има много други удобни функции като събиране на данни, минимизиране на HTML и паралелно изобразяване.