import { effect, ReactiveEffect, activeReactiveEffectStack } from './effect'
-import { Ref, UnwrapNestedRefs } from './ref'
+import { Ref, refSymbol, UnwrapNestedRefs } from './ref'
import { isFunction } from '@vue/shared'
export interface ComputedRef<T> extends Ref<T> {
}
})
return {
- _isRef: true,
+ _isRef: refSymbol,
// expose effect so computed can be stopped
effect: runner,
get value() {
import { isObject } from '@vue/shared'
import { reactive } from './reactive'
+export const refSymbol = Symbol()
+
export interface Ref<T> {
- _isRef: true
+ _isRef: symbol
value: UnwrapNestedRefs<T>
}
export function ref<T>(raw: T): Ref<T> {
raw = convert(raw)
const v = {
- _isRef: true,
+ _isRef: refSymbol,
get value() {
track(v, OperationTypes.GET, '')
return raw
}
export function isRef(v: any): v is Ref<any> {
- return v ? v._isRef === true : false
+ return v ? v._isRef === refSymbol : false
}
export function toRefs<T extends object>(
key: K
): Ref<T[K]> {
const v = {
- _isRef: true,
+ _isRef: refSymbol,
get value() {
return object[key]
},