Category | Utilities |
---|---|
Export Size | 166 B |
Last Changed | 2 weeks ago |
Related | reactify |
Make a plain function accepting ref and raw values as arguments. Returns the same value the unconverted function returns, with proper typing.
Make sure you're using the right tool for the job. Using reactify
might be more pertinent in some cases where you want to evaluate the function on each changes of it's arguments.
import { ref } from 'vue' import { createUnrefFn } from '@vueuse/core' const url = ref('https://httpbin.org/post') const data = ref({ foo: 'bar' }) function post(url, data) { return fetch(url, { data }) } const unrefPost = createUnrefFn(post) post(url, data) /* ❌ Will throw an error because the arguments are refs */ unrefPost(url, data) /* ✔️ Will Work because the arguments will be auto unref */
export type UnrefFn<T> = T extends (...args: infer A) => infer R ? ( ...args: { [K in keyof A]: MaybeRef<A[K]> } ) => R : never /** * Make a plain function accepting ref and raw values as arguments. * Returns the same value the unconverted function returns, with proper typing. */ export declare function createUnrefFn<T extends Function>(fn: T): UnrefFn<T>
© 2019-present Anthony Fu
Licensed under the MIT License.
https://vueuse.org/core/createUnrefFn/