Skip to content
Phillyx edited this page Jun 2, 2022 · 1 revision

useXprovider

  • โšก๏ธ An easy way to manage state
  • ๐Ÿšš An intelligent data pass-through method
  • ๐Ÿ”ฅ Implementing the response data updates by using provider and inject
  • โœ… Supports Vue 2 & 3 using vue-demi
  • ๐Ÿš€ A similar React.Context way of Coding
  • ๐Ÿ’ช Implement intelligent, deeper, powerful type inference with the help of Template Literal Types and Infer Keyword

install

npm i use-x-provider

Demo

Usage

// demo.context.tsx
import { useXprovider } from 'use-x-provider'
import { defineComponent } from 'vue-demi'
import DemoApp from './Demo.vue'

interface IDemoState {
  status: boolean
  foo: {
    bar: {
      a: string
    }
  }
}
const demoState = {
  status: false,
} as IDemoState

const DemoContext = useXprovider<IDemoState>(demoState)

export const setDemoState = DemoContext.setState
export const setDemoStateWithStr = DemoContext.setStateWithStr
export const useDemoContext = DemoContext.useContext

export default defineComponent({
  setup() {
    return () => (
      <DemoContext.ProviderComponent>
        <DemoApp></DemoApp>
      </DemoContext.ProviderComponent>
    )
  },
})
// demo.vue
<template>
  <p>status: {{ demoContext.status }}</p>
  <p>foo.bar.a {{ demoContext.foo.bar.a }}</p>
  <button @click="onclick">setSate</button>
  <button @click="onClick1">setStateWithStr</button>
</template>
<script lang="ts" setup>
import { useDemoContext, setDemoState, setDemoStateWithStr } from './demo.context'

const demoContext = useDemoContext()

const onclick = () => {
  setDemoState({ status: true })
}
const onClick1 = () => {
  setDemoState('foo.bar.a', 'hello world')

  setTimeout(() => {
    // equal to
    setDemoStateWithStr('foo.bar.a','hello vue')
  }, 3e3);
}
</script>

๐Ÿ„๐Ÿบ Type reference

ๅ›พ็‰‡ ๅ›พ็‰‡ ๅ›พ็‰‡

Reference

Clone this wiki locally