-
Notifications
You must be signed in to change notification settings - Fork 0
Home
Phillyx edited this page Jun 2, 2022
·
1 revision
- โก๏ธ An easy way to manage state
- ๐ An intelligent data pass-through method
- ๐ฅ Implementing the response data updates by using
provider
andinject
- โ 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
andInfer Keyword
npm i use-x-provider
// 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>