svelte-qparam

npm-version npm-license npm-download-month npm-min-size ci.yml website

🔎 Type-Safe Query Parameter for SvelteKit

â–· Installation

https://svelte-qparam.jill64.dev/page?

page_str = page_num = 0 page_bool_array = []
// extract.js
import { array, define } from 'svelte-qparam'
import { boolean, number, string } from 'svelte-qparam/serde'

export const extract = define({
  str: string,
  num: number,
  bool_array: array(boolean)
})
<!-- +page.svelte -->
<script>
  import { page } from '$app/state'
  import { extract } from 'extract.js'

  let { qparams: q } = $derived(extract(page.url))
</script>

<div>
  <button onclick={() => {
    q.num = 123
  }}> Set num = 123 </button>
</div>
<output>
  <code>page_str = {q.str}</code>
  <code>page_num = {q.num}</code>
  <code>page_bool_array = {JSON.stringify(q.bool_array)}</code>
</output>