svelte-elements

0.4.2 • Public • Published

svelte-elements

svelte:component is a powerful primitive for rendering components dynamically in svelte, but it doesn't handle html elements... until now.

<!-- Block.svelte -->
<script>
  import { P, Blockquote } from 'svelte-elements';
 
  export let type;
</script> 
 
<svelte:component this="{type === 'blockquote' ? Blockquote : P}">
  <slot />
</svelte:component>

There are some limitations in this approach, namely bind:this does not point to the native element and events are not forwarded by default from the native element. This can be addressed in two ways:

bind:el

Instead of bind:this={ref}, use bind:el={ref}. this points to the wrapper component, el points to the native element

<script>
  import { A } from 'svelte-elements';
 
  let el;
  $: console.log(el); // -> HTMLElement
</script> 
 
<A bind:el href="#">...</A>

listen

Forwarding events from the native element through the wrapper element comes with a cost, so to avoid adding extra event handlers only a few are forwarded. For all elements except <br> and <hr>, on:focus, on:blur, on:keypress, and on:click are forwarded. For audio and video, on:pause and on:play are also forwarded.

For any other events that need to be listened to, you can use the listen property:

<script>
  import { A } from 'svelte-elements';
 
  const preload = () => {};
  const navigate = () => {};
</script> 
 
<A on:click="{navigate}" listen="{{ mouseenter: preload }}">...</A>

Readme

Keywords

Package Sidebar

Install

npm i svelte-elements

Weekly Downloads

0

Version

0.4.2

License

MIT

Unpacked Size

863 kB

Total Files

115

Last publish

Collaborators

  • timhall