fix(reactivity): toRefs should be allowed on plain objects

This commit is contained in:
Evan You 2024-12-09 21:47:55 +08:00
parent b7aec139cb
commit ac43b11897
No known key found for this signature in database
GPG Key ID: 00E9AB7A6704CE0A
2 changed files with 0 additions and 15 deletions

View File

@ -386,16 +386,6 @@ describe('reactivity/ref', () => {
expect(dummyY).toBe(5)
})
test('toRefs should warn on plain object', () => {
toRefs({})
expect(`toRefs() expects a reactive object`).toHaveBeenWarned()
})
test('toRefs should warn on plain array', () => {
toRefs([])
expect(`toRefs() expects a reactive object`).toHaveBeenWarned()
})
test('toRefs reactive array', () => {
const arr = reactive(['a', 'b', 'c'])
const refs = toRefs(arr)

View File

@ -9,7 +9,6 @@ import { Dep, getDepFromReactive } from './dep'
import {
type Builtin,
type ShallowReactiveMarker,
isProxy,
isReactive,
isReadonly,
isShallow,
@ -18,7 +17,6 @@ import {
} from './reactive'
import type { ComputedRef, WritableComputedRef } from './computed'
import { ReactiveFlags, TrackOpTypes, TriggerOpTypes } from './constants'
import { warn } from './warning'
declare const RefSymbol: unique symbol
export declare const RawSymbol: unique symbol
@ -337,9 +335,6 @@ export type ToRefs<T = any> = {
* @see {@link https://vuejs.org/api/reactivity-utilities.html#torefs}
*/
export function toRefs<T extends object>(object: T): ToRefs<T> {
if (__DEV__ && !isProxy(object)) {
warn(`toRefs() expects a reactive object but received a plain one.`)
}
const ret: any = isArray(object) ? new Array(object.length) : {}
for (const key in object) {
ret[key] = propertyToRef(object, key)