Skip to content

Latest commit

 

History

History
62 lines (51 loc) · 1.2 KB

README.md

File metadata and controls

62 lines (51 loc) · 1.2 KB

Valtio Svelte

Combines the power of valtio and svelte stores.

Usage

npm install -D valtio-svelte

Create a proxy store

import {proxy} from 'valtio-svelte'

const person = proxy({
    name: 'elias',
    age: 20,
    hobbys: ['svelte', 'valtio']
})

Now you can just use the $ syntax from svelte to listen to changes

<button on:click={() => person.age++}>Increment Age</button>
<p>Name: {person.name}</p>
<p>Age: {$person.age}</p>

You can also create readable stores for single keys

const hobbys = person.$key('hobbys')

Now, if you have

<script>
    import {proxy} from 'valtio-svelte'
    const person = proxy({
        name: 'elias',
        age: 20,
        hobbys: ['svelte', 'valtio']
    })

    let value = ''
    const handleKey = (event) => {
        if (event.key !== 'Enter')
            return
        person.hobbys.push(value)
        value = ''
    }

    const name = person.$key('name')
    const age = person.$key('age')
    const hobbys = person.$key('hobbys')
</script>

<input bind:value on:keydown={handleKey}>
<p>Name: {$name}</p>
<p>Age: {$age}</p>
<p>Hobbys: {$hobbys.join(', ')}</p>

and you add a hobby only the last paragraph is redrawn