Skip to content

Custom elements powered by @vue/reactivity and uhtml (inspired by vue-lit)

Notifications You must be signed in to change notification settings

andrewbeng89/vue-uhtml

Repository files navigation

vue-uhtml ("vue micro")

Resuable, reactive custom elements framework. Borrows and takes inspiration from @vue/lit. Powered by @vue/reactivity and µhtml

Example

Codepen demo

<my-component></my-component>

<script type="module">
import {
  defineComponent,
  reactive,
  html,
  onMounted,
  onUpdated,
  onUnmounted
} from "https://unpkg.com/vue-uhtml?module";

defineComponent({
  name: "my-component",
  setup: () => {
    const state = reactive({
      text: "hello",
      show: false,
    });
    const toggle = () => {
      state.show = !state.show;
    };
    const onInput = (e) => {
      state.text = e.target.value;
    };

    return () => html`
      <button onclick=${toggle}>toggle child</button>
      <p>
        <span>${state.text}</span>
        <input value=${state.text} oninput=${onInput} />
      </p>
      ${state.show ? html`<my-child msg=${state.text}></my-child>` : ``}
    `;
  },
});

defineComponent({
  name: "my-child",

  props: {
    msg: {
      type: String,
      default: "",
    },
  },

  setup: ({ props }) => {
    const state = reactive({ count: 0 });
    const increase = () => {
      state.count++;
    };

    onMounted(() => {
      console.log("child mounted");
    });

    onUpdated(() => {
      console.log("child updated");
    });

    onUnmounted(() => {
      console.log("child unmounted");
    });

    return () => html`
      <p>${props.msg}</p>
      <p id="count">${state.count}</p>
      <button onclick=${increase}>increase</button>
    `;
  },
});
</script>

Develop

npm run dev

Build

npm run build

Tests

> npm run test

About

Custom elements powered by @vue/reactivity and uhtml (inspired by vue-lit)

Resources

Stars

Watchers

Forks

Packages

No packages published